stl中unique函数,erase函数(个人笔记向)

unique函数

实质

u n i q u e unique unique函数并不是删除相同的元素,而是不断的 c o p y copy copy后面不同的元素到前面连续相同元素的位置上

应用

#include<bits/stdc++.h>

using namespace std;

int main()
{
    vector<int>a(8);
    for (int i = 0;i <= 7;i++)cin >> a[i];//读取2 4 9 7 7 2 2 1
    sort(a.begin(), a.end());
    for (int i = 0;i < a.size();i++)cout << a[i] << ' ';
    cout << '\n';

    vector<int>::iterator erbe = unique(a.begin(), a.end());

    for (int i = 0;i < a.size();i++)cout << a[i] << ' ';
    cout << '\n';
}

在这里插入图片描述

erase函数

删除函数,与 c l e a r ( ) clear() clear()格式化版删除不同, e r a s e erase erase能从特定位置删除特定数量的元素

基本用法

#include<bits/stdc++.h>

using namespace std;

int main()
{
    //基本用法
    string str = "Hello World!";
    cout << str;
    cout << '\n';
    str.erase(5, 3);
    cout << str;
}

在这里插入图片描述

与unique配合

#include<bits/stdc++.h>

using namespace std;

int main()
{
    //与unique配合使用
    vector<int>a(8);
    for (int i = 0;i <= 7;i++)cin >> a[i];//读取2 4 9 7 7 2 2 1
    sort(a.begin(), a.end());
    for (int i = 0;i < a.size();i++)cout << a[i] << ' ';
    cout << '\n';

    vector<int>::iterator erbe = unique(a.begin(), a.end());

    for (int i = 0;i < a.size();i++)cout << a[i] << ' ';
    cout << '\n';

    a.erase(erbe, a.end());

    for (int i = 0;i < a.size();i++)cout << a[i] << ' ';
}

在这里插入图片描述

  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
C++ STL 的 sort 和 unique 函数都是算法函数,用于对指定范围内的元素进行排序和去重。 sort 函数用于对指定范围内的元素进行升序排列,默认使用 operator< 进行比较。sort 函数的定义如下: ```c++ template<class RandomAccessIterator> void sort(RandomAccessIterator first, RandomAccessIterator last); template<class RandomAccessIterator, class Compare> void sort(RandomAccessIterator first, RandomAccessIterator last, Compare comp); ``` 其,first 和 last 分别表示要排序的元素范围的起始和终止位置,包括起始位置但不包括终止位置。如果要排序的元素是一个数组,可以使用数组名和数组名加上元素个数来表示起始和终止位置。 sort 函数的第二个参数 comp 是一个可选的比较函数,用于自定义元素之间的大小关系。如果不指定比较函数,则默认使用 operator<。比较函数需要满足严格弱序关系,即满足: 1. 自反性:对于所有的 x,都有 x <= x。 2. 反对称性:对于所有的 x 和 y,如果 x < y,则 y > x。 3. 传递性:对于所有的 x、y 和 z,如果 x < y 且 y < z,则 x < z。 4. 可比较性:元素之间必须可以进行比较。 unique 函数用于去重,可以将指定范围内相邻的重复元素保留一个,并返回去重后的数组末尾的迭代器。unique 函数的定义如下: ```c++ template<class ForwardIterator> ForwardIterator unique(ForwardIterator first, ForwardIterator last); template<class ForwardIterator, class BinaryPredicate> ForwardIterator unique(ForwardIterator first, ForwardIterator last, BinaryPredicate pred); ``` 其,first 和 last 分别表示要去重的元素范围的起始和终止位置,包括起始位置但不包括终止位置。unique 函数的第二个参数 pred 是一个可选的二元谓词函数,用于自定义元素之间的相等关系。如果不指定二元谓词函数,则默认使用 operator==。二元谓词函数需要满足等价关系,即满足: 1. 自反性:对于所有的 x,都有 pred(x, x) = true。 2. 对称性:对于所有的 x 和 y,有 pred(x, y) = pred(y, x)。 3. 传递性:对于所有的 x、y 和 z,如果 pred(x, y) 且 pred(y, z),则 pred(x, z)。 需要注意的是,unique 函数并不会改变数组的大小,只是将重复元素移到了数组的末尾,并返回去重后的数组末尾的迭代器。因此,去重后的元素个数可以通过数组的起始地址和返回值的差来计算。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值