• <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>
            獨立博客: 哲學與程序

            哲學與程序

            STL之Merge

            STL中合并算法merge介紹,merge與inplace_merge。
            merge合并兩個有序的sequence,默認為<比較,可自定義比較函數(shù)comp,結(jié)果保存在[result, result + (last1 - first1) + (last2 - first2)) 中。函數(shù)定義如下:
            OutputIterator merge (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result)
            OutputIterator merge (InputIterator1 first1, InputIterator1 last1, InputIterator2 first2, InputIterator2 last2, OutputIterator result, Compare comp)

            inplace_merge合并一個中前后兩段分別有序的序列,即[first,middle)與[middle,last)分別有序,合并這兩個子序列,并把結(jié)果保存在[first,last)中。
            inplace_merge (BidirectionalIterator first, BidirectionalIterator middle, BidirectionalIterator last);
            inplace_merge (BidirectionalIterator first, BidirectionalIterator middle, BidirectionalIterator last, Compare comp);

            #include<string>
            #include
            <algorithm>
            #include
            <iostream>
            #include
            <iterator>
            #include
            <vector>
            using namespace std;
            int main()
            {
                vector
            <int>v1;
                vector
            <int>v2;
                vector
            <int>v3;
                vector
            <int>::iterator vecitr;
                
            for(int i = 1; i <= 10; i++){
                    v1.push_back(i
            %7);
                    v2.push_back(i
            %4);
                }
                sort(v1.begin(),v1.end());
                cout 
            << "Fisrt vecter: ";
                copy(v1.begin(),v1.end(),ostream_iterator
            <int>(cout," "));
                cout 
            << endl << endl;
                sort(v2.begin(),v2.end());
                cout 
            << "Second vecter: ";
                copy(v2.begin(),v2.end(),ostream_iterator
            <int>(cout," "));
                cout 
            << endl << endl;
                cout 
            << "Merge this two vecter: ";
                merge(v1.begin(),v1.end(),v2.begin(),v2.end(),ostream_iterator
            <int>(cout," "));
                cout 
            << endl << endl;
                
            for(int i = 1; i <= 10; i++){
                    v3.push_back(i
            %7);
                }
                sort(v3.begin(),v3.end());
                
            int x = v3.size();
                
            for(int i = 1; i <= 10; i++){
                    v3.push_back(i
            %4);
                }
                vecitr 
            = v3.begin();
                advance(vecitr,x);
                sort(vecitr,v3.end());
                cout 
            << "Third vecter: ";
                copy(v3.begin(),v3.end(),ostream_iterator
            <int>(cout," "));
                cout 
            << endl << endl;
                cout 
            << "inplace_Merge third vecter: ";
                inplace_merge(v3.begin(),vecitr,v3.end());
                copy(v3.begin(),v3.end(),ostream_iterator
            <int>(cout," "));
                cout 
            << endl << endl;
                return 0;
            }
            Fisrt vecter: 0 1 1 2 2 3 3 4 5 6

            Second vecter: 
            0 0 1 1 1 2 2 2 3 3

            Merge 
            this two vecter: 0 0 0 1 1 1 1 1 2 2 2 2 2 3 3 3 3 4 5 6

            Third vecter: 
            0 1 1 2 2 3 3 4 5 6 0 0 1 1 1 2 2 2 3 3

            inplace_Merge third vecter: 
            0 0 0 1 1 1 1 1 2 2 2 2 2 3 3 3 3 4 5 6


            posted on 2011-01-17 21:35 哲學與程序 閱讀(1592) 評論(0)  編輯 收藏 引用 所屬分類: AlgorithmC & C++C++ STL

            導(dǎo)航

            公告

            歡迎訪問 http://zhexue.sinaapp.com

            常用鏈接

            隨筆分類(37)

            隨筆檔案(41)

            Algorithm

            最新隨筆

            搜索

            最新評論

            獨立博客: 哲學與程序
            亚洲综合婷婷久久| 久久久久久久久久久久中文字幕 | 久久亚洲精品无码aⅴ大香| 久久精品综合一区二区三区| 久久久久这里只有精品| 亚洲AV无码久久精品成人| 国产精品久久毛片完整版| 久久这里只有精品视频99| 欧美精品乱码99久久蜜桃| 久久天天躁狠狠躁夜夜96流白浆| 久久人妻少妇嫩草AV蜜桃| 久久精品国产亚洲AV忘忧草18| 九九久久精品无码专区| 国产高潮国产高潮久久久| 久久国语露脸国产精品电影| 久久91精品国产91久久户| 久久人人爽人人爽人人片av高请| 9191精品国产免费久久| 无码国内精品久久人妻| 亚州日韩精品专区久久久| 94久久国产乱子伦精品免费| 亚洲精品午夜国产VA久久成人 | 亚洲成av人片不卡无码久久| 久久免费的精品国产V∧| 久久婷婷色香五月综合激情| 久久精品国产只有精品66| 国产亚洲精品美女久久久| 久久综合亚洲色HEZYO社区| 久久精品成人免费国产片小草| 国内精品久久人妻互换| 久久久久se色偷偷亚洲精品av | 久久久久久久久66精品片| 久久久WWW免费人成精品| 伊人久久综在合线亚洲2019| 日韩精品久久久久久| 精品久久久久国产免费| 久久久精品一区二区三区| avtt天堂网久久精品| 欧美一区二区三区久久综| 久久久亚洲AV波多野结衣| 7777精品伊人久久久大香线蕉|