• <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://m.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)論排行榜

            久久久久噜噜噜亚洲熟女综合| 狠狠人妻久久久久久综合| 精品久久亚洲中文无码| 狠狠色丁香久久婷婷综合_中| 亚洲乱码中文字幕久久孕妇黑人| 久久91综合国产91久久精品| 激情久久久久久久久久| 久久一日本道色综合久久| 国产—久久香蕉国产线看观看 | 久久久黄色大片| 久久噜噜电影你懂的| 亚洲AV无码久久精品色欲| 国产精品日韩深夜福利久久| 久久精品国产亚洲av高清漫画| 久久天天躁狠狠躁夜夜av浪潮| 国产亚洲色婷婷久久99精品| 久久久亚洲裙底偷窥综合| 性做久久久久久久久久久| 一本大道久久a久久精品综合| 蜜臀av性久久久久蜜臀aⅴ| 久久精品国产亚洲AV不卡| 日日狠狠久久偷偷色综合0| 99久久婷婷国产综合精品草原| 国产午夜精品理论片久久影视| 日日躁夜夜躁狠狠久久AV| 久久精品国产久精国产果冻传媒| 无码任你躁久久久久久老妇| 久久男人中文字幕资源站| 久久精品国产欧美日韩| 久久精品亚洲男人的天堂| 久久精品成人| 中文字幕无码久久精品青草| 亚洲国产成人精品久久久国产成人一区二区三区综 | 狠狠色婷婷久久综合频道日韩| 色综合久久天天综线观看| 国产毛片久久久久久国产毛片| 办公室久久精品| 超级97碰碰碰碰久久久久最新| 久久亚洲sm情趣捆绑调教| 国产精品99久久久精品无码| 久久婷婷五月综合色奶水99啪|