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

            /********************************************\
            |????歡迎轉載, 但請保留作者姓名和原文鏈接, 祝您進步并共勉!???? |
            \********************************************/


            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. 在你基礎上又改了下, 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);
            可以直接調用滴, 我只是練手^_^ (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年11月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            常用鏈接

            留言簿(7)

            隨筆檔案

            最新隨筆

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久最新精品国产| WWW婷婷AV久久久影片| 久久综合一区二区无码| 久久久久亚洲AV无码永不| 国产叼嘿久久精品久久| 久久久无码精品亚洲日韩按摩| 亚洲国产精品无码久久| 亚洲国产成人精品91久久久 | 久久99精品国产麻豆蜜芽| 一本色道久久综合狠狠躁| 久久福利片| 亚洲女久久久噜噜噜熟女| 丁香五月综合久久激情| 久久精品国产AV一区二区三区| 久久久久亚洲精品无码网址 | 无夜精品久久久久久| 97r久久精品国产99国产精| 中文字幕乱码久久午夜| 成人国内精品久久久久影院VR| 精品伊人久久久| av色综合久久天堂av色综合在| 久久99国产精品久久99果冻传媒 | 久久精品中文字幕第23页| 国产精品激情综合久久| 久久天天躁狠狠躁夜夜网站| 欧美日韩精品久久久久| 国产亚洲精午夜久久久久久| 东京热TOKYO综合久久精品| 欧美va久久久噜噜噜久久| 国内精品伊人久久久久妇| 青春久久| 2021最新久久久视精品爱| 蜜臀久久99精品久久久久久| 精品久久久久久国产免费了| 国内精品久久九九国产精品| 久久精品无码专区免费东京热| 97香蕉久久夜色精品国产| 久久国产精品无| 欧洲精品久久久av无码电影| 少妇人妻88久久中文字幕| 一本一本久久aa综合精品|