C++算法equal() 和 equal_range()

~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

算法

返回值

作用

equal()

bool

比较两个容器数值是否相等

equal_range()

pair<_FwdIt, _FwdIt>

找出搜寻值最佳插入位置

equal()的参数

_InIt1 _First1, _InIt1 _Last1, _InIt2 _First2, _InIt2 _Last2

equal_range()的参数

_FwdIt _First, _FwdIt _Last,const _Ty& _Val

//创建容器

vector<int> createStaticArr()

{

    vector<int> vectorInt;

    vectorInt.push_back(1);   vectorInt.push_back(2);

    vectorInt.push_back(3);   vectorInt.push_back(4);

    vectorInt.push_back(5);   vectorInt.push_back(6);

    vectorInt.push_back(7);   vectorInt.push_back(8);

    showArr(vectorInt);

    return vectorInt;

}

 

vector<int> createStaticArrTwo()

{

    vector<int> vectorInt;

    vectorInt.push_back(1);   vectorInt.push_back(2);

    vectorInt.push_back(3);   vectorInt.push_back(4);

    vectorInt.push_back(5);   vectorInt.push_back(9);

    vectorInt.push_back(8);   vectorInt.push_back(7);

    showArr(vectorInt);   return vectorInt;

}

//输出数组

void showArr(vector<int> Arr)

{

    vector<int>::iterator iteArr = Arr.begin();

    for (iteArr ; iteArr != Arr.end(); iteArr++)

    {

         cout << *iteArr << "\t";

    }

    cout << endl;

}

 

//比较

bool my_equal(vector<int> left, vector<int> right)

{

    return equal(left.begin(), left.end(), right.begin(), right.end());

}

 

void main()

{

    cout << "第一条:"; vector<int> arr1 = createStaticArr();

    cout << "第二条:"; vector<int> arr2 = createStaticArr();

    //使用equal()方法进行比较

    bool my_bool = my_equal(arr1, arr2);

    if (my_bool)

    {

         cout << "一致" << endl;

    }

    else

    {

         cout << "不一致" << endl;

    }

 

    vector<int> arr3 = createStaticArrTwo();

    //排序

    sort(arr3.begin(), arr3.end());

    cout << "第三条:"; showArr(arr3);

    //使用equal_range()方法

    pair<vector<int>::iterator, vector<int>::iterator> my_range = equal_range(arr3.begin(), arr3.end(), 3);

    cout << *my_range.first << endl;

    cout << *my_range.second << endl;

}//输出结果:

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值