• <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>
            Cpper
            C/C++高級工程師 Android高級軟件工程師 IT集成工程師 音頻工程師 熟悉c,c++,java,c#,py,js,asp等多種語言 程序猿
            這段時間沒咋編程序
            就寫個c++排列組合函數(shù)的使用吧
            以后使用得著的
            #include <iostream>
            #include 
            <vector>
            #include 
            <algorithm>
            #include 
            <boost/assign.hpp>
            #include 
            <boost/function.hpp>

            using namespace std;
            using namespace boost;
            using namespace boost::assign;

            inline 
            void print_(int t){cout<<t<<" ";}
            inline 
            void print(vector<int>& vec)
            {
                for_each(vec.begin(),vec.end(),print_);
                cout
            <<endl;
            }

            //! 全排列測試
            void test1()
            {
                vector
            <int> vec;
                vec 
            += 1,2,3,4,5,6,7,8;
                sort(vec.begin(),vec.end());
                
            int i = 0;
                
            do
                {
                   print(vec);
                   i
            ++;
                }
                
            while(next_permutation(vec.begin(),vec.end()));
                std::cout
            <<i<<std::endl;
            }

            //! 組合測試
            size_t test2(int n,int m,boost::function<void(std::vector<int>& vec)> fn)
            {
                vector
            <int> p,set;
                p.insert(p.end(),m,
            1);
                p.insert(p.end(),n
            -m,0);
                
            for(int i = 0;i != p.size();++i)
                    
            set.push_back(i+1);
                vector
            <int> vec;
                size_t cnt 
            = 0;
                
            do{
                    
            for(int i = 0;i != p.size();++i)
                        
            if(p[i])
                           vec.push_back(
            set[i]);
                    fn(vec);
                    cnt 
            ++;
                    vec.clear();
                }
            while(prev_permutation( p.begin(), p.end()));
                
            return cnt;
            }

            int main()
            {
                test1();
                std::cout
            <<test2(20,3,print)<<std::endl;
                
            return 0;
            }
            ....................................................................................................................

            posted on 2010-12-29 11:21 ccsdu2009 閱讀(7483) 評論(5)  編輯 收藏 引用 所屬分類: 雜項boost庫等
            Comments
            • # re: c++排列組合函數(shù)
              ClassyK
              Posted @ 2010-12-30 13:43
              我只能再說一次,既然都用stl了,何必自己寫排列組合。。
              盡管我的話有點傷人,不過還是希望樓主可以熟悉一下stl中的所有算法,避免自己造輪子  回復(fù)  更多評論   
            • # re: c++排列組合函數(shù)
              陳梓瀚(vczh)
              Posted @ 2010-12-31 10:46
              std::function也出現(xiàn)了,你可以不用boost那個了。  回復(fù)  更多評論   
            • # re: c++排列組合函數(shù)
              陳梓瀚(vczh)
              Posted @ 2010-12-31 10:46
              @ClassyK
              人家坐著爽嘛,我也覺得自己造輪子有益身心健康。  回復(fù)  更多評論   
            • # re: c++排列組合函數(shù)
              Θ§奏之章℡
              Posted @ 2011-08-05 13:22
              vector<int> vec;
              vec += 1,2,3,4,5,6,7,8;

              這是什么寫法?boost添加的么?  回復(fù)  更多評論   
            • # re: c++排列組合函數(shù)
              空明流轉(zhuǎn)
              Posted @ 2011-09-27 11:07
              @Θ&#167;奏之章℡
              boost.assign  回復(fù)  更多評論   
             
            97久久国产综合精品女不卡| 无码任你躁久久久久久老妇| 久久精品国产男包| 久久综合亚洲欧美成人| 亚洲天堂久久精品| 久久久午夜精品| 精品国产综合区久久久久久 | 精品久久久无码21p发布| 国产成人精品三上悠亚久久| 久久97精品久久久久久久不卡| 国产精品女同久久久久电影院| 青青青青久久精品国产h久久精品五福影院1421| 久久精品国产影库免费看| 亚洲国产另类久久久精品| 久久精品国产亚洲Aⅴ香蕉| 国产亚洲欧美精品久久久| 精品久久久久久成人AV| 亚洲色欲久久久综合网| 亚洲乱码中文字幕久久孕妇黑人 | 99久久99久久精品国产| 久久91这里精品国产2020| 久久综合日本熟妇| 久久精品国产乱子伦| www久久久天天com| 欧美777精品久久久久网| 国产精品亚洲综合专区片高清久久久| 99久久精品无码一区二区毛片 | 久久天堂AV综合合色蜜桃网| 亚洲第一极品精品无码久久| 久久精品国产秦先生| 国产综合精品久久亚洲| 亚洲国产精品无码久久久蜜芽| 国产精品一区二区久久不卡| 久久久久国产| 97久久精品人人做人人爽| 综合网日日天干夜夜久久| 久久毛片免费看一区二区三区| 久久99久久99精品免视看动漫| 人人妻久久人人澡人人爽人人精品| 欧美黑人激情性久久| 久久AV无码精品人妻糸列|