• <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)載, 但請保留作者姓名和原文鏈接, 祝您進(jì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是改進(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)
            {?? //省去一變量, 時間換空間法
            ??? 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 閱讀(1122) 評論(7)  編輯 收藏 引用

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

            BTW: //Feature: This version is suitable for both sring and array
            這個更離譜了,string還好說,array如何能用呢?  回復(fù)  更多評論
              
            # 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;
            }  回復(fù)  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-24 13:15 | oosky
            @沐楓
            這個好多了。
              回復(fù)  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 00:51 | Jerry Cat
            沐楓兄說得對:
            1. 沒必要另外分配一個內(nèi)存了.
            2. "array如何能用呢?", 忘加一定語:叫字符數(shù)組:)
            3. 在你基礎(chǔ)上又改了下, BTW, 都是面試惹的禍(你指風(fēng)格不太好, 反正看它要求啦, 有的面官就要你用兩行最多三行寫完成某一功能的函數(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;
            }
              回復(fù)  更多評論
              
            # 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--);  回復(fù)  更多評論
              
            # re: C與C++編程一頭一尾最重要, 無數(shù)英雄折腰, 多少豪杰翻船!
            2006-04-25 18:31 | Jerry Cat
            1. "估計遇到這樣的for語句,在某些大公司是會被警告直至走人的。
            干嘛非要放到括號里完成呢?"
            ---------------------------
            答: 面試惹的禍, 有的面官就要你用兩行最多三行寫完成某一功能的函數(shù). 咱又不是不會用所謂"好"風(fēng)格的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中就有標(biāo)準(zhǔn)庫函數(shù): char* strrev(char* str);
            可以直接調(diào)用滴, 我只是練手^_^ (BTW, 現(xiàn)在嵌入式開發(fā)可以用C++(以前只許ams和C哦), 但還不允許C++標(biāo)準(zhǔn)庫STL), 不知貴公司的情況了:)

            4. 歡迎沐楓兄多指教, 謝了!  回復(fù)  更多評論
              
            # 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() :)  回復(fù)  更多評論
              

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



            <2006年9月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            1234567

            常用鏈接

            留言簿(7)

            隨筆檔案

            最新隨筆

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            国产精品99久久精品| 日韩精品久久无码人妻中文字幕| 久久久久久久尹人综合网亚洲| 国产精品一区二区久久不卡 | 中文精品久久久久人妻不卡| 久久久无码精品亚洲日韩京东传媒| 久久强奷乱码老熟女网站| 老司机国内精品久久久久| 亚洲国产精品综合久久一线| 国产精品久久久久久吹潮| 久久亚洲精品无码观看不卡| 天天躁日日躁狠狠久久| 欧美久久一级内射wwwwww.| 麻豆成人久久精品二区三区免费| 国产日韩久久久精品影院首页 | 久久精品国产亚洲Aⅴ香蕉| 久久99精品久久久大学生| 久久精品国产一区二区电影| 色综合久久久久无码专区| 久久国产成人午夜aⅴ影院 | 久久精品亚洲一区二区三区浴池 | 色综合久久无码中文字幕| 国产精品女同一区二区久久| 久久精品九九亚洲精品| 精品伊人久久久| 久久精品一区二区三区AV| 久久免费99精品国产自在现线| 精品一区二区久久| 99精品久久精品一区二区| 麻豆一区二区99久久久久| 一本色综合网久久| 18岁日韩内射颜射午夜久久成人 | 亚洲欧美精品伊人久久| 99久久无色码中文字幕| 久久99精品久久只有精品| 亚洲国产精品无码久久一区二区 | 日本久久久精品中文字幕| av无码久久久久久不卡网站| 国产精品久久久久久久| 国产成人综合久久综合| 99热热久久这里只有精品68|