• <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>
            asm, c, c++ are my all
            -- Core In Computer
            posts - 139,  comments - 123,  trackbacks - 0

            /********************************************\
            |????歡迎轉(zhuǎn)載, 但請(qǐng)保留作者姓名和原文鏈接, 祝您進(jìn)步并共勉!???? |
            \********************************************/


            C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!

            作者: Jerry Cat
            時(shí)間: 2006/04/22
            鏈接: http://www.shnenglu.com/jerysun0818/archive/2006/04/22/6086.aspx


            #include <stdio.h>
            #include <stdlib.h>
            #include <string.h>

            //Fuction: BOOL revstr(char *str);
            //Purpose: reverse a string
            //Author:? Jerry
            //Time:???? 04/22/2006
            //Feature: This version is suitable for both sring and char array

            char* revstr(char *str)
            {
            ??? int nCnt = 0, len = strlen(str);
            ??? char* tmpstr = (char*) malloc(len+1);
            ??? if???? (tmpstr) strcpy(tmpstr, str);
            ??? else { printf("\n malloc error!\n"); return 0; }
            ??? for(--len, tmpstr = tmpstr + len; len > 0; *str++ = *tmpstr--, --len, ++nCnt);
            ??? *str = *tmpstr; //C/C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!
            ??? free(tmpstr);
            ??? return str - nCnt;
            }

            上面方法不好, 繁雜且易出錯(cuò), 經(jīng)沐楓兄指點(diǎn), 下面?zhèn)z是改進(jìn)版^_^
            char* revstr(char *str)
            {
            ??? char c, *head = str, *tail = str + strlen(str) -1;
            ??? for(; head < tail; c = *head, *head++ = *tail, *tail-- = c);
            ??? return str;
            }

            char* revstr(char *str)
            {?? //省去一變量, 時(shí)間換空間法
            ??? char *head = str, *tail = str + strlen(str) -1;
            ??? for(; head < tail; *head=*head ^ *tail, *tail=*head ^ *tail, *head=*head++ ^ *tail--);
            ??? return str;
            }
            ?

            posted on 2006-04-22 22:20 Jerry Cat 閱讀(1138) 評(píng)論(7)  編輯 收藏 引用

            FeedBack:
            # re: C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-24 09:23 | 沐楓
            代碼風(fēng)格應(yīng)該受到批評(píng)。
            就這么幾行的程序,就讓人看得難以理解--特別是那個(gè)恐怖的for.
            而且就本程序來(lái)說(shuō),沒(méi)必要另外分配一個(gè)內(nèi)存。

            BTW: //Feature: This version is suitable for both sring and array
            這個(gè)更離譜了,string還好說(shuō),array如何能用呢?  回復(fù)  更多評(píng)論
              
            # re: C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-24 09:58 | 沐楓
            char* revstr(char* str){
              char* head = str;
              char* tail = head + strlen(head) -1;
              while(head < tail) {
                char c = *head;
                *head++ = *tail;
                *tail-- = c;
              }
              return str;
            }  回復(fù)  更多評(píng)論
              
            # re: C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-24 13:15 | oosky
            @沐楓
            這個(gè)好多了。
              回復(fù)  更多評(píng)論
              
            # re: C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 00:51 | Jerry Cat
            沐楓兄說(shuō)得對(duì):
            1. 沒(méi)必要另外分配一個(gè)內(nèi)存了.
            2. "array如何能用呢?", 忘加一定語(yǔ):叫字符數(shù)組:)
            3. 在你基礎(chǔ)上又改了下, BTW, 都是面試惹的禍(你指風(fēng)格不太好, 反正看它要求啦, 有的面官就要你用兩行最多三行寫(xiě)完成某一功能的函數(shù), 這種情況不要太多了:)

            char* revstr(char *str)
            {
            char c, *head = str, *tail = str + strlen(str) -1;
            for(; head < tail; c = *head, *head++ = *tail, *tail-- = c);
            return str;
            }

            char* revstr(char *str)
            { //省去一變量, 時(shí)間換空間法
            char *head = str, *tail = str + strlen(str) -1;
            for(; head < tail; *head=*head ^ *tail, *tail=*head ^ *tail, *head=*head++ ^ *tail--);
            return str;
            }
              回復(fù)  更多評(píng)論
              
            # re: C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 09:10 | 沐楓
            估計(jì)遇到這樣的for語(yǔ)句,在某些大公司是會(huì)被警告直至走人的。
            干嘛非要放到括號(hào)里完成呢?

            另外,字符數(shù)組你這程序是不能用的。
            我給你一個(gè)測(cè)試用例:
            char arr[5] = {'H', 'e', 'l', 'l', 'o'};

            ----------
            BTW,你如果要指定是C++,那么,C++中已經(jīng)有reverse函數(shù)(頭文件algorithm):
            reverse(str, str+strlen(str)-1);
            而交換變量,也有swap函數(shù)(頭文件algorithm):
            swap(*head++, *tail--);  回復(fù)  更多評(píng)論
              
            # re: C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 18:31 | Jerry Cat
            1. "估計(jì)遇到這樣的for語(yǔ)句,在某些大公司是會(huì)被警告直至走人的。
            干嘛非要放到括號(hào)里完成呢?"
            ---------------------------
            答: 面試惹的禍, 有的面官就要你用兩行最多三行寫(xiě)完成某一功能的函數(shù). 咱又不是不會(huì)用所謂"好"風(fēng)格的for和while. 它需要啥咱就給它啥, 咱要工作! 它不需警告, 只要它皺眉頭, 咱就改, 咱還不是給逼的嗎?

            2. "另外,字符數(shù)組你這程序是不能用的。
            我給你一個(gè)測(cè)試用例:
            char arr[5] = {'H', 'e', 'l', 'l', 'o'};
            ------------------------------------------
            答: 提的好, 它沒(méi)有第六個(gè)字節(jié)放'\0'! 我指的是:
            char arr[6] = {'H', 'e', 'l', 'l', 'o', '\0'};
            char arr[] = "Hello";
            這樣的"串"形字符數(shù)組, anyway you're a careful guy!

            3. "BTW,你如果要指定是C++,那么,C++中已經(jīng)有reverse函數(shù)(頭文件algorithm):
            reverse(str, str+strlen(str)-1);
            而交換變量,也有swap函數(shù)(頭文件algorithm):
            swap(*head++, *tail--);
            -----------------------------------------
            答: 哈, 我沒(méi)指?jìng)鹘y(tǒng)C++, 或STL式C++, 看看頭文件就知道了:)
            在C中就有標(biāo)準(zhǔn)庫(kù)函數(shù): char* strrev(char* str);
            可以直接調(diào)用滴, 我只是練手^_^ (BTW, 現(xiàn)在嵌入式開(kāi)發(fā)可以用C++(以前只許ams和C哦), 但還不允許C++標(biāo)準(zhǔn)庫(kù)STL), 不知貴公司的情況了:)

            4. 歡迎沐楓兄多指教, 謝了!  回復(fù)  更多評(píng)論
              
            # re: C與C++編程一頭一尾最重要, 無(wú)數(shù)英雄折腰, 多少豪杰翻船![未登錄](méi)
            2011-06-03 15:20 | z
            "*tail = str + strlen(str) -1;"

            char* tail = str;
            while(*tail) ++tail;
            --tail;

            //remove the reference to strlen() :)  回復(fù)  更多評(píng)論
              

            只有注冊(cè)用戶登錄后才能發(fā)表評(píng)論。
            網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問(wèn)   Chat2DB   管理



            <2006年7月>
            2526272829301
            2345678
            9101112131415
            16171819202122
            23242526272829
            303112345

            常用鏈接

            留言簿(7)

            隨筆檔案

            最新隨筆

            搜索

            •  

            最新評(píng)論

            閱讀排行榜

            評(píng)論排行榜

            99久久中文字幕| 亚洲国产成人久久精品动漫| 精品久久久久久久久免费影院 | 97久久天天综合色天天综合色hd| 波多野结衣中文字幕久久| 免费一级做a爰片久久毛片潮| 成人免费网站久久久| 日本精品久久久久影院日本| 日韩精品久久久久久| 久久精品人人做人人爽电影蜜月 | 94久久国产乱子伦精品免费| 久久精品亚洲AV久久久无码| 国产精品成人久久久| 精品少妇人妻av无码久久| 久久亚洲精品国产精品婷婷| 色婷婷综合久久久久中文字幕 | 国产精品禁18久久久夂久| 一级做a爰片久久毛片人呢| 久久AV无码精品人妻糸列| 国产综合免费精品久久久| 久久综合狠狠色综合伊人| 久久久久国产精品嫩草影院| 久久久无码精品午夜| 久久91这里精品国产2020| 国产一区二区三区久久| 天天综合久久久网| 日韩精品久久久久久久电影蜜臀| 久久国产免费观看精品3| 中文精品久久久久人妻| 国产偷久久久精品专区| 99精品久久精品一区二区| 一本色道久久HEZYO无码| 亚洲国产另类久久久精品小说| 久久国产色AV免费看| 狠狠色狠狠色综合久久| 国产成人无码精品久久久性色| 欧美日韩精品久久久久| 新狼窝色AV性久久久久久| 狼狼综合久久久久综合网| 国产欧美一区二区久久| 久久国产福利免费|