最近发现了一个好玩的函数,可以去掉重复的数字或者字母,感觉很强大,以后再也 写那么多的代码了,两行核心代码就能搞定。
unique一般都是与sort连着用。
#include<algorithm>//排序头文件
#include<iostream>
sort(f,f+n);//对函数进行排序
int m = unique(f,f+n)-f;//m返回的是前n个元素中不同元素的个数
//如果要输出,只需要输出前m个不同的元素就行了。至于后面的元素,都存在了数组后面,没有删除。
来做一道题试一下:
nyoj:小明的调查作业
时间限制:1000 ms | 内存限制:65535 KB
难度:1
描述
小明的老师布置了一份调查作业,小明想在学校中请一些同学一起做一项问卷调查,聪明的小明为了实验的客观性,想利用自己的计算机知识帮助自己。他先用计算机生成了N个1到1000之间的随机整数(0
#include<algorithm>
#include<iostream>
using namespace std;
int main()
{
int n,f[1000],m;
cin>>n;
for(int i=0;i<n;i++)
cin>>f[i];
sort(f,f+n);
m=unique(f,f+n)-f;
cout<<m<<'\n';
for(int i=0;i<m;i++)
cout<<f[i]<<' ';
cout<<'\n'<<endl;
return 0;
}
觉得这样写好多了,不用再写那么多代码了。