• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            posts - 71,  comments - 41,  trackbacks - 0

            MS面試曾出過這樣一道題目,將給定字符串按單詞翻轉,如,"This is Charles" -> "Charles is This"

            方法一,需要額外緩沖區

            ?1 #include? < cstring >
            ?2 void ?ReverseByWords( char ? * s,? char ?seperator)
            ?3 {
            ?4 ???? int ?iRevTokenScanner? = ?strlen(s)? - ? 1 ;
            ?5 ???? char ? * buffer? = ? new ? char [iRevTokenScanner? + ? 2 ]();
            ?6 ???? int ?iWritePos? = ? 0 ;
            ?7 ???? int ?iWordEnd,?iWordReadPos;
            ?8
            ?9 ???? while ?(iRevTokenScanner? >= ? 0 )
            10 ???? {
            11 ???????? if ?(s[iRevTokenScanner]? != ?seperator)
            12 ???????? {
            13 ????????????iWordEnd? = ?iRevTokenScanner;
            14 ????????????
            15 ???????????? while ?(iRevTokenScanner? >= ? 0 ? && ??s[iRevTokenScanner]? != ?seperator)
            16 ????????????????iRevTokenScanner -- ;
            17 ????????????
            18 ????????????iWordReadPos? = ?iRevTokenScanner? + ? 1 ;
            19
            20 ???????????? while ?(iWordReadPos? <= ?iWordEnd)
            21 ????????????????buffer[iWritePos ++ ]? = ?s[iWordReadPos ++ ];
            22 ????????}

            23 ???????? else
            24 ???????? {
            25 ????????????buffer[iWritePos ++ ]? = ?s[iRevTokenScanner -- ];
            26 ????????}
            ?
            27 ????}

            28
            29 ????buffer[iWritePos]? = ? ' \0 ' ;
            30 ????strcpy(s,?buffer);
            31
            32 ???? if ?(buffer)
            33 ???? {
            34 ????????delete?[]?buffer;
            35 ????????buffer? = ? 0 ;
            36 ????}

            37 }

            方法二,個人比較prefer
            ?1void?ReverseString(char?*s,?int?start,?int?end)
            ?2{
            ?3????while?(start?<?end)
            ?4????{
            ?5????????if?(s[start]?!=?s[end])
            ?6????????{
            ?7????????????s[start]?^=?s[end];
            ?8????????????s[end]?^=?s[start];
            ?9????????????s[start]?^=?s[end];
            10????????}

            11????????????????
            12????????start++;
            13????????end--;
            14????}

            15}

            16
            17void?ReverseByWords(char?*s,?int?len,?char?seperator)
            18{
            19????int?start?=?0,?end?=?0;
            20
            21????ReverseString(s,?start,?len?-?1);
            22
            23????while?(end?<?len)
            24????{
            25????????if?(s[end]?!=?seperator)
            26????????{
            27????????????start?=?end;
            28
            29????????????while?(end?<?len?&&?s[end]?!=?seperator)
            30????????????????end++;
            31????????????end--;
            32
            33????????????ReverseString(s,?start,?end);
            34????????}

            35????????
            36????????end++;
            37
            38????}
            //while
            39}

            等有空再回來作注釋吧,現在挺忙的,先把code貼出來
            posted on 2006-11-16 18:50 Charles 閱讀(429) 評論(0)  編輯 收藏 引用 所屬分類: 面試小算法
            <2006年11月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            決定開始寫工作日記,記錄一下自己的軌跡...

            常用鏈接

            留言簿(4)

            隨筆分類(70)

            隨筆檔案(71)

            charles推薦訪問

            搜索

            •  

            積分與排名

            • 積分 - 50778
            • 排名 - 448

            最新評論

            閱讀排行榜

            評論排行榜

            国产成人精品综合久久久久| 狠狠精品久久久无码中文字幕 | 精品久久久久久国产91| 亚洲国产天堂久久综合网站| 久久午夜无码鲁丝片午夜精品| 日韩久久久久中文字幕人妻| 狠狠综合久久AV一区二区三区| AV狠狠色丁香婷婷综合久久 | 国内精品久久久久久久影视麻豆| 日批日出水久久亚洲精品tv| 国内精品伊人久久久久AV影院| 久久93精品国产91久久综合| 色偷偷久久一区二区三区| 国产福利电影一区二区三区,免费久久久久久久精 | 精品99久久aaa一级毛片| 99久久国产综合精品女同图片| 欧美777精品久久久久网| 久久精品国产亚洲AV蜜臀色欲| 999久久久免费国产精品播放| 亚洲精品乱码久久久久久自慰| 久久99国产精品成人欧美| 国产一久久香蕉国产线看观看 | 一本大道久久香蕉成人网| 99久久99久久精品免费看蜜桃 | 精品久久久久久中文字幕大豆网 | 亚洲а∨天堂久久精品9966| 亚洲国产成人久久精品影视| 久久久精品人妻一区二区三区四| 中文字幕无码久久精品青草| 久久精品国产福利国产琪琪| 热99re久久国超精品首页| 亚洲色欲久久久综合网东京热| 一本久久a久久精品综合香蕉| 久久亚洲AV永久无码精品| 成人精品一区二区久久| 久久久久中文字幕| 精品久久久久久无码中文野结衣| 热re99久久精品国产99热| 中文字幕亚洲综合久久| 国内精品久久久久久久影视麻豆| 久久精品无码一区二区三区日韩|