今天就跟大家聊聊有關(guān)怎么用編程語(yǔ)言分析左旋字符串中的k個(gè)字符,可能很多人都不太了解,為了讓大家更加了解,小編給大家總結(jié)了以下內(nèi)容,希望大家根據(jù)這篇文章可以有所收獲。
成都創(chuàng)新互聯(lián)長(zhǎng)期為上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營(yíng)造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為淮安區(qū)企業(yè)提供專業(yè)的成都網(wǎng)站制作、網(wǎng)站建設(shè),淮安區(qū)網(wǎng)站改版等技術(shù)服務(wù)。擁有十余年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。看這么一個(gè)問題:
1.實(shí)現(xiàn)一個(gè)函數(shù),可以左旋字符串中的k個(gè)字符。
ABCD左旋一個(gè)字符得到BCDA
ABCD左旋兩個(gè)字符得到CDAB
拿到問題后,我們首先應(yīng)該理解題意。什么是左旋?根據(jù)例題可以看出是把k個(gè)字符經(jīng)過左旋放到后面,下面給出兩種方法來求解:
#include <stdio.h> #include <stdlib.h> #include <assert.h> #include <string.h> void left_move(char* str, int k) { int j = 0; for(j=0; j<k; j++) { //旋轉(zhuǎn)1個(gè)字符 char tmp = *str; int len = strlen(str); int i = 0; for(i=0; i<len-1; i++) { *(str+i) = *(str+i+1); } *(str+len-1) = tmp; } } int main() { char arr[] = "abcdef";//cdefab left_move(arr, 8); printf("%s\n", arr); system("pause"); return 0; }
這種方法的優(yōu)點(diǎn)是容易想到,實(shí)現(xiàn)起來比較容易。保利求解思想就是你給一個(gè)k我就給你左旋k個(gè)字符串,但也存在一些缺點(diǎn),比如可能存在某些問題。下面我們來看另一個(gè)較優(yōu)方法。
我們來先看代碼:
#include <stdio.h> #include <stdlib.h> #include <assert.h> #include <string.h> void reverse_str(char *left, char *right) { assert(left != NULL); assert(right != NULL); while(left<right) { char tmp = *left; *left = *right; *right = tmp; left++; right--; } } void left_move(char* str, int k) { int len = 0; assert(str != NULL); len = strlen(str); reverse_str(str, str+k-1); reverse_str(str+k, str+len-1); reverse_str(str, str+len-1); } int main() { char arr[] = "abcdef";//cdefab left_move(arr, 8); printf("%s\n", arr); system("pause"); return 0; }
這個(gè)方法比較靈活,他根據(jù)abcdef先在k個(gè)字符左右先各自左旋得到字符串bafedc,再將整個(gè)字符串整體左旋得到所求字符串cdefab;這個(gè)方法比較靈性,它合理的將問題拆分,化成一個(gè)個(gè)來求解,所以這里比較推薦第二個(gè)方法。
看完上述內(nèi)容,你們對(duì)怎么用編程語(yǔ)言分析左旋字符串中的k個(gè)字符有進(jìn)一步的了解嗎?如果還想了解更多知識(shí)或者相關(guān)內(nèi)容,請(qǐng)關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道,感謝大家的支持。
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國(guó)服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡(jiǎn)單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢(shì),專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場(chǎng)景需求。
網(wǎng)站標(biāo)題:怎么用編程語(yǔ)言分析左旋字符串中的k個(gè)字符-創(chuàng)新互聯(lián)
文章轉(zhuǎn)載:http://m.rwnh.cn/article32/cedgpc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供網(wǎng)站營(yíng)銷、云服務(wù)器、網(wǎng)頁(yè)設(shè)計(jì)公司、域名注冊(cè)、品牌網(wǎng)站設(shè)計(jì)、品牌網(wǎng)站制作
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容