C++标准模板库——modifying algorithms

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

using namespace std;
/* 
* 本文介绍会改变元素值的标准模板库算法
* value-changing algorithm - change the element values
* copy,move,transform,swap,fill,replace,remove
 */
int main()
{
    vector<int> vec = {9,60,70,8,45,87,90}; //7 items
    vector<int> vec2(11,0); // 11 items
    vector<int>::iterator itr,itr2;
    pair<vector<int>::iterator,vector<int>::iterator> pair_of_itr;

    //? 1.copy
    //将vec中的所有元素复制到vec2中。copy共接收3个参数,前两个参数为数值范围,第三个参数指明复制到的位置
    copy(vec.begin(),vec.end(), //source
         vec2.begin());         //destination
    //将vec中满足条件的值复制到vec2中
    copy_if(vec.begin(),vec.end(), //source
            vec2.begin(),          //destination
            [](int x){return x>80;}); //condition
    //将vec的前4个数复制到vec2中
    copy_n(vec.begin(),4,vec2.begin());
    //将vec中的值复制到vec2的后面
    copy_backward(vec.begin(),vec.end(), //source
                  vec2.begin());         //destinaton
    //vec2:{0,0,0,0,9,60,70,8,45,87,90}

    //? 2.move
    vector<string> vec3 = {"apple","orange","pear","grape"};//4 items
    vector<string> vec4(6,""); // 6 items

    move(vec3.begin(),vec3.end(),vec4.begin());
    //vec3:{"","","",""}
    //vec4:{"apple","orange","pear","grape","",""};

    move_backward(vec3.begin(),vec3.end(),vec4.end());
    //vec4:{"","","apple","orange","pear","grape"}

    //? 3.transform
    vector<int> vec5(vec); //{9,60,70,8,45,87,90}; 7 items
    vector<int> vec6(vec); //{9,60,70,8,45,87,90}; 7 items
    vector<int> vec7(11,0);// 11 items
    //将vec5中的每个元素都减1再复制到vec7中,vec5的元素不变!
    transform(vec5.begin(),vec5.end(), //source
              vec7.begin(),          //destination
              [](int x){return x-1;}); //operation

    transform(vec5.begin(),vec5.end(), //source1
              vec6.begin(),            //source2
              vec7.begin(),            //destination
              [](int x,int y){return x+y;}); //operation
    // add items from vec5 and vec6 and save in vec7
    // vec7[0] = vec5[0] + vec6[0];
    // vec7[1] = vec5[1] + vec6[1];...

    //? 4.swap 交换两个容器
    swap_ranges(vec5.begin(),vec5.end(),vec2.begin());

    //? 5.fill 填充值
    vector<int> vec8(5,0);

    fill(vec8.begin(),vec8.end(),9); //vec8:{9,9,9,9,9}

    fill_n(vec8.begin(),3,9); //vec8:{9,9,9,0,0}
    
    generate(vec8.begin(),vec8.end(),rand);

    generate_n(vec8.begin(),3,rand);

    //? 6.replace
    // 把vec中的所有6都替换成9
    replace(vec.begin(),vec.end(), //data range
            6,                     //old value condition
            9);                    //new value
    //把vec中大于80的值都替换成9
    replace_if(vec.begin(),vec.end(), //data range
               [](int x){return x>80;}, //old value condition
               9);                                  //new value
    //把vec中的等于9的元素都替换成6再复制到vec2中,vec中的元素不变!
    replace_copy(vec.begin(),vec.end(), //source
                 vec2.begin(),          //destination
                 9,                     //old value condition
                 6);                    //new value
    
    //? 7. remove
    // 把vec中所有等于3的值全部删掉
    remove(vec.begin(),vec.end(),3);
    // 把vec中大于80的值全部删掉
    remove_if(vec.begin(),vec.end(),[](int x){return x>80;});
    // 把vec中等于6的值全部删掉,再把剩余的值复制到vec2中,且vec中的值保持不变!
    remove_copy(vec.begin(),vec.end(), //source
                vec2.begin(),          //destination
                6);                    //condition
    
    system("pause");
    return 0;
}

内容概要:本文档介绍了一个多目标规划模型,该模型旨在优化与水资源分配相关的多个目标。它包含四个目标函数:最小化F1(x),最大化F2(x),最小化F3(x)和最小化F4(x),分别对应于不同的资源或环境指标。每个目标函数都有具体的数值目标,如F1的目标值为1695亿立方米水,而F2则追求达到195.54亿立方米等。此外,模型还设定了若干约束条件,包括各区域内的水量限制以及确保某些变量不低于特定百分比的下限。特别地,为了保证模型的有效性和合理性,提出需要解决目标函数间数据尺度不一致的问题,并建议采用遗传算法或其他先进算法进行求解,以获得符合预期的决策变量Xi(i=1,2,...,14)的结果。 适合人群:对数学建模、运筹学、水资源管理等领域感兴趣的科研人员、高校师生及从业者。 使用场景及目标:①适用于研究涉及多目标优化问题的实际案例,尤其是水资源分配领域;②帮助读者理解如何构建和求解复杂的多目标规划问题,掌握处理不同尺度数据的方法;③为从事相关工作的专业人士提供理论参考和技术支持。 阅读建议:由于文档涉及到复杂的数学公式和专业术语,在阅读时应先熟悉基本概念,重点关注目标函数的具体定义及其背后的物理意义,同时注意理解各个约束条件的设计意图。对于提到的数据尺度不一致问题,建议深入探讨可能的解决方案,
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值