• <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>

            XY

            沒有任何借口
            posts - 9, comments - 31, trackbacks - 0, articles - 0
              C++博客 :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

            反轉(zhuǎn)字符串

            Posted on 2008-06-04 16:22 路緣 閱讀(9834) 評論(2)  編輯 收藏 引用 所屬分類: C/C++
            題目:
                    編寫函數(shù)reverse_string,它的原型如下:
                        void reverse_string(char *str);
                     函數(shù)把參數(shù)字符串中的字符串反向排列。請使用指針而不是數(shù)組下標(biāo),不要使用任何C函數(shù)庫中用于操縱字符串的函數(shù)。提示:不要聲明一個(gè)局部數(shù)組來臨時(shí)存儲參數(shù)字符串。
                     
            算法:
                   關(guān)于反轉(zhuǎn)字符串的方法很多。這里我給出我想到的一種算法。
                 
            /************反轉(zhuǎn)字符串************/
            void reverse_str(char *str)
            {
                
            char *cp = str;
                
            int i=0;
                
            while(*str!= '\0')
                
            {
                    str
            ++;
                    i
            ++;
                }


                i 
            /= 2;
                str
            --;
                
            while(i-- > 0)
                
            {
                    
            *str ^= *cp;
                    
            *cp ^= *str;
                    
            *str ^= *cp;

                    str
            --;
                    cp
            ++;
                }

            }

            說明:
                     算法中運(yùn)用了:a ^ a = 0  和 a ^ 0 = a 的特性。以此來進(jìn)行變量值的交換,可以避免使用額外的臨時(shí)變量。

            Feedback

            # re: 反轉(zhuǎn)字符串  回復(fù)  更多評論   

            2012-11-15 22:28 by 周翀
            三次異或可以互換兩個(gè)值,也可以毀掉兩個(gè)值,當(dāng)它們相等的時(shí)候……

            # re: 反轉(zhuǎn)字符串  回復(fù)  更多評論   

            2017-09-29 22:46 by 路緣
            @周翀
            剛一看,嚇我一跳,以為一直認(rèn)為的解法有問題。細(xì)想一下,值相等也無妨。當(dāng)毀掉其中一個(gè)值后,再做異或,另一個(gè)值就會得到保留,做第3次計(jì)算,毀掉的那個(gè)值也被恢復(fù)了,所以沒有問題。
            久久精品无码一区二区三区| 99蜜桃臀久久久欧美精品网站| 国产综合久久久久久鬼色| 日本精品久久久中文字幕| 久久久99精品成人片中文字幕| 国内精品伊人久久久影院| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久久久久国产精品无码下载| 影音先锋女人AV鲁色资源网久久| 国产成人AV综合久久| 久久天天躁狠狠躁夜夜avapp| 国产精品美女久久久久av爽| 亚洲AV无码久久精品色欲| 久久久亚洲精品蜜桃臀| 国产精品久久自在自线观看| 国内精品伊人久久久久777| 国产毛片久久久久久国产毛片 | 亚洲国产精品成人久久| 国产成人综合久久精品尤物| 久久久久国产精品熟女影院| 午夜视频久久久久一区| 99久久亚洲综合精品成人| 久久久老熟女一区二区三区| 国内精品久久久久影院亚洲| 久久久综合香蕉尹人综合网| 日本福利片国产午夜久久| 777米奇久久最新地址| 国产精品久久久久jk制服| 久久精品国产亚洲av影院| 亚洲精品国精品久久99热一| 久久午夜福利无码1000合集| 亚洲国产一成久久精品国产成人综合 | 久久99这里只有精品国产| 久久久久亚洲av成人无码电影| 亚洲乱亚洲乱淫久久| 日本道色综合久久影院| 精品久久久久久国产三级| 久久性生大片免费观看性| 久久人人爽人爽人人爽av| 亚洲国产成人久久一区久久| 三级三级久久三级久久|