国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 學(xué)院 > 開(kāi)發(fā)設(shè)計(jì) > 正文

關(guān)于字符串旋轉(zhuǎn)技巧編程題

2019-11-06 06:48:28
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

1.輸入一個(gè)英語(yǔ)句子,翻轉(zhuǎn)句子中單詞的順序,但單詞內(nèi)字符的順序不變。為簡(jiǎn)單起見(jiàn),標(biāo)點(diǎn)符號(hào)和普通字母一樣處理。例如輸入字符串“I am a student。”,則輸出“student. a am I”。

算法思想:先翻轉(zhuǎn)整個(gè)句子,然后,依次翻轉(zhuǎn)每個(gè)單詞。并依據(jù)空格來(lái)判斷單詞起始和終止的位置。

可執(zhí)行代碼:

public class Solution {    public String ReverseSentence(String str) {        char[] chars = str.toCharArray();        reverse(chars, 0, chars.length - 1);        int blank = -1;        for(int i = 0;i < chars.length;i++){            if(chars[i] == ' '){   //若句子中存在空格                int nextBlank = i;                reverse(chars,blank + 1,nextBlank - 1);                blank = nextBlank;            }        }        reverse(chars,blank + 1,chars.length - 1);   //句子中的最后一個(gè)單詞進(jìn)行翻轉(zhuǎn)        return new String(chars); }    PRivate void reverse(char[] chars,int low,int high){        char temp;        while(low < high){            temp = chars[low];            chars[low] = chars[high];            chars[high] = temp;            low++;            high--;         }    }}2.舉一反三:對(duì)于一個(gè)給定的字符序列S,請(qǐng)你把其循環(huán)左移K位后的序列輸出。例如,字符序列S=”abcXYZdef”,要求輸出循環(huán)左移3位后的結(jié)果,即“XYZdefabc”。

算法思想:把上述字符串看成兩部分,前三個(gè)字符以及剩余的字符。首先,對(duì)前三個(gè)字符進(jìn)行翻轉(zhuǎn);然后對(duì)剩余部分進(jìn)行翻轉(zhuǎn);最后,對(duì)整個(gè)字符串進(jìn)行翻轉(zhuǎn)。

可執(zhí)行代碼:

public class Solution {    public String LeftRotateString(String str,int n) {        int len = str.length();        if(len == 0) return "";        n = n % len;        char[] chars = str.toCharArray();        reverse(chars,0,n - 1);        reverse(chars,n,chars.length - 1);        reverse(chars,0,chars.length - 1);        return new String(chars);    }    private void reverse(char[] chars,int low,int high){        char temp;        while(low < high){            temp = chars[low];            chars[low] = chars[high];            chars[high] = temp;            low++;            high--;        }    }}


發(fā)表評(píng)論 共有條評(píng)論
用戶名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 阜新市| 石河子市| 甘泉县| 陈巴尔虎旗| 遂川县| 潮州市| 泸水县| 米泉市| 乐安县| 彭山县| 措美县| 郴州市| 茶陵县| 武穴市| 吴川市| 即墨市| 永春县| 喜德县| 宣化县| 烟台市| 清新县| 桦川县| 武山县| 剑阁县| 阳山县| 合山市| 鹤山市| 嘉禾县| 大宁县| 乌拉特后旗| 长春市| 乌审旗| 定远县| 布尔津县| 靖远县| 璧山县| 常州市| 台南市| 扎囊县| 禹州市| 峨眉山市|