九、常用算法(算數(shù)滑凉、集合算法统扳、distance算法、for_each反向)

1.常用算數(shù)生成算法

#include <iostream>
#include <vector>
#include <numeric>
#include <algorithm> //for_each
using namespace std;

//accumulate 累計
void test01(){
    vector<int> v;
    for(int i = 0;i<=100;i++){
        v.push_back(i);
    }

    /*  
    template<class _InIt,
    class _Ty> inline
    _Ty accumulate(_InIt _First, _InIt _Last, _Ty _Val)  返回值是最終結果加上參數(shù)三譬涡!所以是用0最方便
    {   // return sum of _Val and all in [_First, _Last)
    return (_STD accumulate(_First, _Last, _Val, plus<>()));
    }
    */
    int n = accumulate(v.begin(),v.end(),0);
    cout<<"n: "<<n<<endl;//5050
}


//fill algorithm   填充函數(shù)
class print{
    void operatpr()(int v){
        cout<<v<<" ";
    }
}
void test02(){
    vector<int> v;
    v.resize(10);//用fill必須開空間 而reserve只是開空間 沒有初始化闪幽,所以不能再這里用
    fill(v.begin(),v.end(),100);

    cout<<"size:"<<v.size()<<endl;
    for_each(v.begin(),v.end(),print());
    cout<<endl;
}


int main(){

   //test01();
    test02();
   return 0;
}

2.常用集合算法

iterator set_intersection(iterator beg1,iterator end1,iterator beg2,iterator end2,iterator dest);
/*
   set_intersection 算法 求兩個set集合的交集
   注意:兩個集合必須是有序序列
   @param beg1 容器1開始迭代器
   @param end1 容器1結束迭代器
   @param beg2 容器2開始迭代器
   @param end2 容器2結束迭代器
   @param dest 目標容器開始迭代器
   @return 目標容器的最后一個元素的迭代器地址
*/

iterator set_union(iterator beg1,iterator end1,iterator beg2,iterator end2,iterator dest);
/*
   set_union 算法 求兩個set集合的并集
   注意:兩個集合必須是有序序列
   @param beg1 容器1開始迭代器
   @param end1 容器1結束迭代器
   @param beg2 容器2開始迭代器
   @param end2 容器2結束迭代器
   @param dest 目標容器開始迭代器
   @return 目標容器的最后一個元素的迭代器地址
*/

iterator set_difference(iterator beg1,iterator end1,iterator beg2,iterator end2,iterator dest);
/*
   set_difference 算法 求兩個set集合的差集
   注意:兩個集合必須是有序序列
   @param beg1 容器1開始迭代器
   @param end1 容器1結束迭代器
   @param beg2 容器2開始迭代器
   @param end2 容器2結束迭代器
   @param dest 目標容器開始迭代器
   @return 目標容器的最后一個元素的迭代器地址
*/

//---------------------------------------------------------------
#include <iostream>
#include <vector>
#include <numeric>
#include <algorithm> //for_each
using namespace std;

//求兩個集合的交集
class print{
public:
    void operator()(int v){
        cout<<v<<" ";
    }
}

void test01(){
    vector<int> v1,v2,v3;
    for (int i = 0; i < 10; ++i)
    {
        v1.push_back(i);
    }

    for (int i = 5; i < 15; ++i)
    {
        v2.push_back(i);
    }


    /*
        template<class _InIt1,
        class _InIt2,
        class _OutIt> inline
        _OutIt set_intersection(_InIt1 _First1, _InIt1 _Last1,
        _InIt2 _First2, _InIt2 _Last2, _OutIt _Dest)
        {   // AND sets [_First1, _Last1) and [_First2, _Last2), using operator<
        return (_STD set_intersection(_First1, _Last1, _First2, _Last2, _Dest,
        less<>()));
        }
    */
    
    v3.resize(min(v1.size(),v2.size()));
    vector<int>::iterator myEnd = set_intersection(v1.begin(),v1.end(),v2.begin(),v2.end(),v3.begin());
   
    //for_each(v3.begin(),v3.end(),print());
    //多余的位置會顯示0,怎么解決涡匀?
    //set_intersection的返回值,是一個迭代器溉知!一個知道尾部的迭代器陨瘩!

    for_each(v3.begin(),myEnd,print());
}

//求兩個容器的并集
void test02(){
    vector<int> v1,v2,v3;
    for (int i = 0; i < 10; ++i)
    {
        v1.push_back(i);
    }

    for (int i = 5; i < 15; ++i)
    {
        v2.push_back(i);
    }
    /*
    template<class _InIt1,
    class _InIt2,
    class _OutIt> inline
    _OutIt set_union(_InIt1 _First1, _InIt1 _Last1,
    _InIt2 _First2, _InIt2 _Last2, _OutIt _Dest)
    {   // OR sets [_First1, _Last1) and [_First2, _Last2), using operator<
    return (_STD set_union(_First1, _Last1, _First2, _Last2, _Dest,
    less<>()));
    }
    */
    v3.resize(v1.size()+v2.size());
    vector<int>::iterator myEnd = set_union(v1.begin(),v1.end(),v2.begin(),v2.end(),v3.begin());
    for_each(v3.begin,myEnd,print());
}

//求差集
void test03(){
    vector<int> v1,v2,v3;
    for (int i = 0; i < 10; ++i)
    {
        v1.push_back(i);
    }

    for (int i = 5; i < 15; ++i)
    {
        v2.push_back(i);
    }

    v3.resize(max(v1.size(),v2.size()));
    vector<int>::iterator myEnd = set_difference(v1.begin(),v1.end(),v2.begin(),v2.end(),v3.begin());
    for_each(v3.begin,myEnd,print());
}

int main(){

   //test01();
   //test02();
   test03();
 
   return 0;
}

3.distance和for_each反向

#include <iostream>
#include <vector>
#include <algorithm>

using namespace std;

//distance 用法
void test01(){
    vector<int> v;
    for(int i = 10; i < 20 ; i++){
        v.push_back(i);
    }

    for(vector<int>::iterator it = v.begin();it != v.end();it++)
    {
       // cout<<distance(v.begin(),it)<<endl;//0 1 2 3 4 5 6 ...就是參數(shù)二和參數(shù)一的距離
        int index = distance(v.begin(),it);
        cout<<v[index]<<" ";//10 11 ......
    }
    cout<<endl;
}

//for_each修改容器元素的值
void print(int &v){
    v = v + 100;//因為要深度修改 所以是引用
}

void print2(const int &v){
    cout<<v<<" ";
}

void test02(){
    vector<int> v;
    for(int i = 10; i < 20 ; i++){
        v.push_back(i);
    }
    for_each(v.begin(),v.end(),print2);//打印 不修改
    cout<<endl;

    for_each(v.begin(),v.end(),print);//只修改 不打印  

    for_each(v.begin(),v.end(),print2);//打印 不修改
    cout<<endl;
}

//for_each逆向遍歷
void test03(){
    vector<int> v;
    for(int i = 10; i < 20 ; i++){
        v.push_back(i);
    }

    for_each(v.begin(),v.end(),print2);
    cout<<endl;

    for_each(v.rbegin(),v.rend(),print2);
    cout<<endl;
}

int main(){
   //test01();
   //test02();
   test03();
   return 0;
}
?著作權歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末腕够,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子舌劳,更是在濱河造成了極大的恐慌帚湘,老刑警劉巖,帶你破解...
    沈念sama閱讀 218,640評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件甚淡,死亡現(xiàn)場離奇詭異大诸,居然都是意外死亡,警方通過查閱死者的電腦和手機贯卦,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,254評論 3 395
  • 文/潘曉璐 我一進店門资柔,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人撵割,你說我怎么就攤上這事贿堰。” “怎么了啡彬?”我有些...
    開封第一講書人閱讀 165,011評論 0 355
  • 文/不壞的土叔 我叫張陵羹与,是天一觀的道長。 經(jīng)常有香客問我庶灿,道長纵搁,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,755評論 1 294
  • 正文 為了忘掉前任往踢,我火速辦了婚禮诡渴,結果婚禮上,老公的妹妹穿的比我還像新娘菲语。我一直安慰自己妄辩,他們只是感情好,可當我...
    茶點故事閱讀 67,774評論 6 392
  • 文/花漫 我一把揭開白布山上。 她就那樣靜靜地躺著眼耀,像睡著了一般。 火紅的嫁衣襯著肌膚如雪佩憾。 梳的紋絲不亂的頭發(fā)上哮伟,一...
    開封第一講書人閱讀 51,610評論 1 305
  • 那天,我揣著相機與錄音妄帘,去河邊找鬼楞黄。 笑死,一個胖子當著我的面吹牛抡驼,可吹牛的內(nèi)容都是我干的鬼廓。 我是一名探鬼主播,決...
    沈念sama閱讀 40,352評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼致盟,長吁一口氣:“原來是場噩夢啊……” “哼碎税!你這毒婦竟也來了尤慰?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,257評論 0 276
  • 序言:老撾萬榮一對情侶失蹤雷蹂,失蹤者是張志新(化名)和其女友劉穎伟端,沒想到半個月后,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體匪煌,經(jīng)...
    沈念sama閱讀 45,717評論 1 315
  • 正文 獨居荒郊野嶺守林人離奇死亡责蝠,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,894評論 3 336
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了萎庭。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片霜医。...
    茶點故事閱讀 40,021評論 1 350
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖擎椰,靈堂內(nèi)的尸體忽然破棺而出支子,到底是詐尸還是另有隱情,我是刑警寧澤达舒,帶...
    沈念sama閱讀 35,735評論 5 346
  • 正文 年R本政府宣布值朋,位于F島的核電站,受9級特大地震影響巩搏,放射性物質(zhì)發(fā)生泄漏昨登。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,354評論 3 330
  • 文/蒙蒙 一贯底、第九天 我趴在偏房一處隱蔽的房頂上張望丰辣。 院中可真熱鬧,春花似錦禽捆、人聲如沸笙什。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,936評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽琐凭。三九已至,卻和暖如春浊服,著一層夾襖步出監(jiān)牢的瞬間统屈,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 33,054評論 1 270
  • 我被黑心中介騙來泰國打工牙躺, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留愁憔,地道東北人。 一個月前我還...
    沈念sama閱讀 48,224評論 3 371
  • 正文 我出身青樓孽拷,卻偏偏與公主長得像吨掌,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,974評論 2 355

推薦閱讀更多精彩內(nèi)容