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

            A Za, A Za, Fighting...

            堅信:勤能補拙

            PKU 1731 Orders

            問題:
            http://acm.pku.edu.cn/JudgeOnline/problem?id=1731

            思路:
            求全排列,這個問題本身挺簡單,不過題目要求: a. 不能重復(fù);b. 有序輸出
            記得曾經(jīng)做過這題,當(dāng)時偷懶用STL過的(真要自己寫,估計當(dāng)時也不會(*^__^*) 嘻嘻……)
            現(xiàn)在,決心棄用C++來做題,好好鍛煉基本功,所以就硬著頭皮自己慢慢寫
            好在前段時間對于搜索題有了一定的積累,否則相信自己肯定還是不知道怎么寫的
            找個例子,畫出遞歸調(diào)用樹,對于理解有很大幫助

            純C遞歸實現(xiàn)如下:
            代碼:
             1 /* 364K 454MS */
             2 #include<stdio.h>
             3 #include<stdlib.h>
             4 #include<string.h>
             5 #define MAX_LEN 201
             6 char str[MAX_LEN];
             7 int len;
             8 
             9 int
            10 compare(const void *arg1, const void *arg2) /* for qsort */
            11 {
            12     return *((char *)arg1) - *((char *)arg2);
            13 }
            14 
            15 void
            16 swap(char *seq, int i, int j) /* exchange */
            17 {
            18     char tmp = seq[i];
            19     seq[i] = seq[j];
            20     seq[j] = tmp;
            21 }
            22 
            23 void
            24 perm(char *seq, int begin, int end)
            25 {
            26     int i, j, tmp;
            27     char pre=0;
            28     if(begin >= end) {
            29         printf("%s\n", seq);
            30         return;
            31     }
            32     for(i=begin; i<=end; i++) {
            33         if(i>begin && seq[i]==seq[begin]) /* avoid duplicates */
            34             continue;
            35         if(pre == seq[i]) /* avoid duplicate */
            36             continue;
            37         /* in order to keep the alphabetical order */
            38         tmp = seq[i];
            39         for(j=i; j>begin; j--)
            40             seq[j] = seq[j-1];
            41         seq[begin] = tmp;
            42         perm(seq, begin+1, end);
            43         tmp = seq[begin];
            44         for(j=begin; j<i; j++)
            45             seq[j] = seq[j+1];
            46         seq[i] = tmp;
            47         /*
            48         swap(seq, begin, i);
            49         perm(seq, begin+1, end);
            50         swap(seq, begin, i);
            51         */
            52         pre = seq[i];
            53     }
            54 }
            55 
            56 int
            57 main(int argc, char **argv)
            58 {
            59     while(scanf("%s", str) != EOF) {
            60         len = strlen(str);
            61         qsort(str, len, sizeof(char), compare);
            62         perm(str, 0, len-1);
            63     }
            64 }



            posted on 2010-08-15 09:10 simplyzhao 閱讀(123) 評論(0)  編輯 收藏 引用 所屬分類: G_其他

            導(dǎo)航

            <2010年9月>
            2930311234
            567891011
            12131415161718
            19202122232425
            262728293012
            3456789

            統(tǒng)計

            常用鏈接

            留言簿(1)

            隨筆分類

            隨筆檔案

            搜索

            最新評論

            閱讀排行榜

            評論排行榜

            久久精品国产精品国产精品污| 久久久久国产日韩精品网站| 亚洲av成人无码久久精品| 久久青青草原精品国产| 国内精品久久久久影院网站| 亚洲综合伊人久久综合| 国产91久久综合| 久久精品国产亚洲av麻豆小说 | 久久国产美女免费观看精品| 女人高潮久久久叫人喷水| 国产精品久久波多野结衣| 亚洲v国产v天堂a无码久久| 国产精品久久久久9999| 99精品国产免费久久久久久下载 | 激情五月综合综合久久69| 亚洲国产精品成人久久| 久久综合狠狠综合久久97色| 丁香五月网久久综合| 亚洲va久久久噜噜噜久久男同 | 久久综合九色综合久99| 99久久国产精品免费一区二区| 久久久青草青青国产亚洲免观| 久久综合狠狠色综合伊人| 久久久久久无码Av成人影院| 精品久久久久久中文字幕大豆网| 久久久精品国产亚洲成人满18免费网站 | 久久久久国产一级毛片高清板| 国产精品无码久久综合| 久久精品国产亚洲AV嫖农村妇女 | 久久99精品国产自在现线小黄鸭 | 久久精品中文騷妇女内射| 人妻精品久久久久中文字幕一冢本| 欧美亚洲另类久久综合婷婷| 久久久久黑人强伦姧人妻| 久久国产成人精品国产成人亚洲| 狠狠精品干练久久久无码中文字幕 | 亚洲欧美日韩久久精品第一区| 东方aⅴ免费观看久久av| 成人久久免费网站| 91久久精一区二区三区大全| 久久免费小视频|