对于这种既需要去重 有需要排序 的数列,我们可以使用 STL 中的 set 容器,它不仅可以去重 ,且还可以排序,正好符合题目标准。
思路
- 我们先定义一个 set 容器 st,接着输入 n 个数。提示:输入的 n 个数可以不用数组。
- 随后将所有输入的 t 给 insert 进去,此时在 set 容器里的数将自动完成去重 和排序的任务。
- 题目中说明了需要先输出一个数,代表 st 的长度,这时可以用 size 来输出。(size 代表长度)
我们可以用 2 种使用 set 的输出方法:
第一种:
cpp
for(auto it:st){
cout<<it<<' ';
}
第二种:
cpp
for(auto it = st.begin();it!=st.end();it++){
cout<<*it<<' ';
}
AC CODE:
cpp
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
set<int> st;
int main(){
int n;
cin>>n;
for(int i=1;i<=n;i++){
int t;
cin>>t;
st.insert(t);
}
cout<<st.size()<<endl;
for(auto it:st){
cout<<it<<' ';
}
return 0;
}
注意:正确代码不是唯一的,也可以用数组模拟去重和排序的过程。