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

            寫出一個可以工作的程序并不夠

            統計

            留言簿(3)

            積分與排名

            良師益友

            閱讀排行榜

            評論排行榜

            #

            全排列

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

            此算法要求待排列的數據是互異的,因為該算法不能檢測同種排列是否已經輸出,如:
            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

            這是該算法的缺點,也限制了它的適用范圍。

            程序描述如下:

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

            using ? namespace ?std;?

            // ?遞歸產生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中的范型算法,當然效果是很好的,不會出現上面的算法的情況。

            程序描述如下:

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

            using ? namespace ?std;?

            // ?產生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()函數必須是有序的數據
            ?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()));
            }

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

            posted @ 2006-12-25 10:17 Dain 閱讀(1140) | 評論 (2)編輯 收藏

            算法求解(還沒有人做出來,唉)

                 摘要: Given an int m and a vector a containing n numbers, return the result of the following expression:   閱讀全文

            posted @ 2006-12-21 10:58 Dain 閱讀(1008) | 評論 (6)編輯 收藏

            衛星還是光纖

            我們能訪問其他國家的網絡,比如美國,那些數據是通過什么方式傳送的啊?衛星,還是海底光纖
            要是海底光纖,那要鋪很長地阿
            who來說說哈

            posted @ 2006-12-13 13:41 Dain 閱讀(340) | 評論 (3)編輯 收藏

            string和int間的類型轉換

            int 轉換 string
            string ?int2str( int ?num)
            {
            ???
            if (num? == ? 0 )
            ??????
            return ? " 0 " ;
            ???
            ???
            string ?str? = ? "" ;
            ???
            int ?num_? = ?num? > ? 0 ? ? ?num?:? - 1 ? * ?num;

            ???
            while (num_)
            ???
            {
            ??????str?
            = ?( char )(num_? % ? 10 ? + ? 48 )? + ?str;
            ??????num_?
            /= ? 10 ;
            ??? }


            ???
            if (num? < ? 0 )
            ??????str?
            = ? " - " ? + ?str;

            ???
            return ?str;
            }
            string 轉換 int
            int ?str2int( string ?str)
            {
            ???
            int ?i,len? = ?str.size(),num? = ? 0 ;

            ??? i?
            = ? 0 ;???
            ???
            if (str[ 0 ]? == ? ' - ' )
            ??????i?
            = ? 1 ;
            ???
            ???
            while (i? < ?len)
            ???
            {
            ??????num?
            = ?num? * ? 10 ? + ?( int )(str[i]? - ? ' 0 ' );
            ??????i
            ++ ;
            ??? }


            ???
            if (str[ 0 ]? == ? ' - ' )
            ??????num?
            *= ? - 1 ;

            ???
            return ?num;
            }

            string和int間是可以自己寫函數實現類型轉換的,但是string和double就不太方便了,stirng轉換double可以自定義函數實現,但是,double轉換string就需要使用庫函數了,如sprintf

            posted @ 2006-12-10 13:05 Dain 閱讀(13589) | 評論 (10)編輯 收藏

            勵志

            師兄太強了,拿到了baidu、M$、Google的offer,可是實驗室第一人啊,實在是admire
            現在都說工作難找,不過只要努力,總會找到自己滿意的,向師兄學習
            我一定要努力啊

            posted @ 2006-12-08 10:42 Dain 閱讀(864) | 評論 (14)編輯 收藏

            僅列出標題
            共2頁: 1 2 
            久久精品国产99国产精偷| 精品国产日韩久久亚洲| 亚洲国产日韩欧美久久| 狠狠色噜噜色狠狠狠综合久久| 婷婷五月深深久久精品| 久久久久久久综合日本亚洲| 欧美国产精品久久高清| 久久香综合精品久久伊人| 国产叼嘿久久精品久久| 综合久久国产九一剧情麻豆| 99久久精品日本一区二区免费| 9999国产精品欧美久久久久久| 久久亚洲AV无码精品色午夜麻豆| 国产亚洲精品自在久久| 午夜精品久久久久成人| 成人国内精品久久久久影院VR| 伊人久久大香线蕉亚洲五月天| 99久久精品无码一区二区毛片| 色天使久久综合网天天| 岛国搬运www久久| 国产精品9999久久久久| 国产精品久久新婚兰兰| 国内精品免费久久影院| 精品无码久久久久久午夜| 久久精品国产久精国产果冻传媒| 久久久久久av无码免费看大片| 国产精品无码久久综合| 精品久久久久久国产| 欧美粉嫩小泬久久久久久久| 精品99久久aaa一级毛片| 99久久免费国产精品| 99久久夜色精品国产网站| 99精品久久精品| 久久国产精品99国产精| 午夜精品久久久久久99热| 久久99精品久久久大学生| 少妇熟女久久综合网色欲| 午夜精品久久久久成人| 亚洲精品tv久久久久久久久久| 亚洲&#228;v永久无码精品天堂久久| 国产叼嘿久久精品久久|