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

            Dain

            寫出一個(gè)可以工作的程序并不夠

            統(tǒng)計(jì)

            留言簿(3)

            積分與排名

            良師益友

            閱讀排行榜

            評論排行榜

            全排列

            首先,給出算法的思路
            設(shè)R={r1,r2,...,rn}是要進(jìn)行排列的n個(gè)元素,Ri=R-{ri}。
            集合X中元素的全排列記為permutation(X),(ri)permutation(X)表示在全排列permutation(X)的每一個(gè)排列前加上前綴ri得到的排列。
            R的全排列可歸納定義如下:
            當(dāng)n=1時(shí),permutation(R)={r},r是集合R中唯一的元素;
            當(dāng)n>1時(shí),permutation(R)由(r1)permutation(R1),(r2)permutation(R2),……,(rn)permutation(Rn)構(gòu)成。

            此算法要求待排列的數(shù)據(jù)是互異的,因?yàn)樵撍惴ú荒軝z測同種排列是否已經(jīng)輸出,如:
            1, 1, 2
            那么,全排列期望輸出是:
            1, 1, 2
            1, 2, 1
            2, 1, 1
            但是該算法的輸出:
            1, 1, 2
            1, 2, 1
            2, 1, 1
            1, 1, 2
            1, 2, 1
            2, 1, 1

            這是該算法的缺點(diǎn),也限制了它的適用范圍。

            程序描述如下:

            #include? < iostream >
            #include?
            < algorithm > ?

            using ? namespace ?std;?

            // ?遞歸產(chǎn)生R[k:n]的所有的排列,元素是互異的
            template? < class ?Type >
            void ?permutation(Type? * R, int ?k, int ?n)
            {
            ????
            if (k == n)
            ????{
            ????????
            for ( int ?i = 0 ;i < n; ++ i)
            ????????????cout?
            << ?R[i]? << ? " \t " ;
            ????????cout?
            << ?endl;
            ????}
            ????
            else
            ????????
            for ( int ?i = k;i < n; ++ i)
            ????????{
            ????????????swap(R[k],R[i]);
            ????????????permutation(R,k
            + 1 ,n);
            ????????????swap(R[k],R[i]);
            ????????}
            }

            還有一種很簡單的方法,使用GP中的方法

            該算法是STL中的范型算法,當(dāng)然效果是很好的,不會出現(xiàn)上面的算法的情況。

            程序描述如下:

            // ?使用泛型算法next_permutation()
            #include? < iostream >
            #include?
            < vector >
            #include?
            < algorithm > ?

            using ? namespace ?std;?

            // ?產(chǎn)生R[k:n]的所有的排列
            template? < class ?Type > ?

            void ?pernutation(Type? * R, int ?k, int ?n)
            {
            ?vector
            < Type > ?myVec;
            ?
            int ?i,size? = ?n? - ?k;
            ?
            for (i? = ?k;i? < ?n;i ++ )
            ??myVec.push_back(R[i]);
            ?
            // ?使用next_permutation()函數(shù)必須是有序的數(shù)據(jù)
            ?sort(myVec.begin(),myVec.end());
            ??
            ?
            do
            ?{
            ??
            for (i? = ? 0 ;i? < ?size;i ++ )
            ???cout?
            << ?myVec[i]? << ? " \t " ;
            ??cout?
            << ?endl;
            ?}
            ?
            while (next_permutation(myVec.begin(),myVec.end()));
            }

            注:這里的待全排的數(shù)據(jù)是存在數(shù)組或者向量中的。

            posted on 2006-12-25 10:17 Dain 閱讀(1139) 評論(2)  編輯 收藏 引用 所屬分類: 算法

            評論

            # re: 全排序 2006-12-25 10:35 Dain

            有興趣,可以將遞歸改成非遞歸  回復(fù)  更多評論   

            # re: 全排列 2007-06-22 00:00 ryan

            很清楚,謝謝!  回復(fù)  更多評論   

            亚洲午夜福利精品久久| 久久精品麻豆日日躁夜夜躁| 国产精品久久久久久吹潮| 综合久久久久久中文字幕亚洲国产国产综合一区首 | 国产A级毛片久久久精品毛片| 久久久av波多野一区二区| 中文国产成人精品久久不卡| 久久国产AVJUST麻豆| 伊人色综合久久天天人手人婷 | 久久精品国产精品亚洲精品| 久久噜噜电影你懂的| 51久久夜色精品国产| 久久精品国产99久久久香蕉| 久久青青草原精品国产不卡| 国产69精品久久久久观看软件| 伊人久久大香线蕉综合Av| 人妻无码αv中文字幕久久琪琪布 人妻无码久久一区二区三区免费 人妻无码中文久久久久专区 | 精品熟女少妇aⅴ免费久久| 一级做a爰片久久毛片人呢| 久久久这里有精品中文字幕| 久久人人爽人人人人片av| 久久久久免费看成人影片| 国产A级毛片久久久精品毛片| 亚洲国产精品综合久久一线| 久久久亚洲裙底偷窥综合| 精品国产乱码久久久久久1区2区 | 午夜精品久久久久成人| 亚洲AV无一区二区三区久久| 久久久无码人妻精品无码| 99久久精品国产麻豆| 久久婷婷五月综合成人D啪| 成人午夜精品无码区久久| 狠狠狠色丁香婷婷综合久久五月 | 国产美女久久精品香蕉69| 精品国产一区二区三区久久蜜臀| 国产精品亚洲综合久久| 日本久久久精品中文字幕| 2020久久精品亚洲热综合一本| 亚洲国产精品久久久久| 亚洲精品美女久久久久99| 午夜视频久久久久一区 |