• <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)載, 但請保留作者姓名和原文鏈接, 祝您進步并共勉!???? |
            \********************************************/


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

            作者: Jerry Cat
            時間: 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++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            ??? free(tmpstr);
            ??? return str - nCnt;
            }

            上面方法不好, 繁雜且易出錯, 經(jīng)沐楓兄指點, 下面?zhèn)z是改進版^_^
            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)
            {?? //省去一變量, 時間換空間法
            ??? 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 閱讀(1121) 評論(7)  編輯 收藏 引用

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

            BTW: //Feature: This version is suitable for both sring and array
            這個更離譜了,string還好說,array如何能用呢?  回復  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(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;
            }  回復  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-24 13:15 | oosky
            @沐楓
            這個好多了。
              回復  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 00:51 | Jerry Cat
            沐楓兄說得對:
            1. 沒必要另外分配一個內(nèi)存了.
            2. "array如何能用呢?", 忘加一定語:叫字符數(shù)組:)
            3. 在你基礎(chǔ)上又改了下, BTW, 都是面試惹的禍(你指風格不太好, 反正看它要求啦, 有的面官就要你用兩行最多三行寫完成某一功能的函數(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)
            { //省去一變量, 時間換空間法
            char *head = str, *tail = str + strlen(str) -1;
            for(; head < tail; *head=*head ^ *tail, *tail=*head ^ *tail, *head=*head++ ^ *tail--);
            return str;
            }
              回復  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 09:10 | 沐楓
            估計遇到這樣的for語句,在某些大公司是會被警告直至走人的。
            干嘛非要放到括號里完成呢?

            另外,字符數(shù)組你這程序是不能用的。
            我給你一個測試用例:
            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--);  回復  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 18:31 | Jerry Cat
            1. "估計遇到這樣的for語句,在某些大公司是會被警告直至走人的。
            干嘛非要放到括號里完成呢?"
            ---------------------------
            答: 面試惹的禍, 有的面官就要你用兩行最多三行寫完成某一功能的函數(shù). 咱又不是不會用所謂"好"風格的for和while. 它需要啥咱就給它啥, 咱要工作! 它不需警告, 只要它皺眉頭, 咱就改, 咱還不是給逼的嗎?

            2. "另外,字符數(shù)組你這程序是不能用的。
            我給你一個測試用例:
            char arr[5] = {'H', 'e', 'l', 'l', 'o'};
            ------------------------------------------
            答: 提的好, 它沒有第六個字節(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--);
            -----------------------------------------
            答: 哈, 我沒指傳統(tǒng)C++, 或STL式C++, 看看頭文件就知道了:)
            在C中就有標準庫函數(shù): char* strrev(char* str);
            可以直接調(diào)用滴, 我只是練手^_^ (BTW, 現(xiàn)在嵌入式開發(fā)可以用C++(以前只許ams和C哦), 但還不允許C++標準庫STL), 不知貴公司的情況了:)

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

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

            //remove the reference to strlen() :)  回復  更多評論
              

            <2006年10月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(7)

            隨筆檔案

            最新隨筆

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            欧美牲交A欧牲交aⅴ久久| 亚洲日韩欧美一区久久久久我| 性高朝久久久久久久久久| 伊人久久大香线蕉成人| 亚洲精品无码久久久影院相关影片| 久久99精品久久只有精品| 精品久久久久久无码人妻热| 亚洲七七久久精品中文国产| 久久无码人妻一区二区三区| 精品久久久久中文字| 色婷婷综合久久久久中文一区二区| 国产成人综合久久综合 | 蜜桃麻豆WWW久久囤产精品| 久久久久人妻一区精品性色av| 精品欧美一区二区三区久久久| 亚洲精品国产美女久久久| 日本久久久久久中文字幕| 日韩精品久久久久久久电影| 久久久久久久综合日本亚洲 | 久久99精品久久久大学生| 草草久久久无码国产专区| 久久久国产精华液| 国产综合免费精品久久久| 久久精品草草草| 麻豆AV一区二区三区久久| 久久婷婷午色综合夜啪| 久久精品国产黑森林| 久久99精品国产| AV狠狠色丁香婷婷综合久久 | 久久久久婷婷| 国产高潮久久免费观看| 国产国产成人精品久久| 国产精品久久久久久影院| 久久久久国产精品熟女影院| 久久国产免费直播| 精品久久人人爽天天玩人人妻| 欧美久久久久久| 欧美日韩精品久久久免费观看| 久久se这里只有精品| 日本亚洲色大成网站WWW久久| 精品国产91久久久久久久a|