2415: 【例】【入门】【P1059】明明的随机数(1765)
内存限制:128 MB
时间限制:1.000 S
评测方式:文本比较
命题人:
提交:53
解决:40
题目描述
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了 个 到 之间的随机整数 ,对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。
输入
输入有两行,第 行为 个正整数,表示所生成的随机数的个数 。
第 行有 个用空格隔开的正整数,为所产生的随机数。
输出
输出也是两行,第 行为 个正整数 ,表示不相同的随机数的个数。
第 行为 个用空格隔开的正整数,为从小到大排好序的不相同的随机数。
样例输入 复制
10
20 40 32 67 40 20 89 300 400 15
样例输出 复制
8
15 20 32 40 67 89 300 400
提示
#include <iostream>
#include <algorithm>
using namespace std;
int const MAXN = 1010;
int a[MAXN],ans[MAXN],n,cnt=0,tmp =-1;
int main() {
cin >> n;
for (int i=0; i<n; i++) cin >> a[i];
sort(a,a+n);
cnt=unique(a,a+n)-a;
cout<<cnt<<endl;
for(int i=0;i<cnt;i++) cout<<a[i]<<' ';
return 0;
}
#include <iostream>
#include <algorithm>
using namespace std;
int const MAXN = 1010;
int a[MAXN],ans[MAXN],n,cnt=0,tmp =-1;
int main() {
cin >> n;
for (int i=0; i<n; i++) cin >> a[i];
sort(a,a+n);
for (int i =0; i<n; i++) {
if(a[i]!=tmp) ans[cnt++]=a[i]; /*当前的和上一个不同才复制到新数组*/
tmp=a[i];
}
cout << cnt << endl;
for (int i=0; i<cnt; i++) cout << ans[i] <<' ';
return 0;
}
#include<bits/stdc++.h>
using namespace std;
set<int> s;
int n,i,t;
int main(){
cin>>n;
for (i=0;i<n;i++) {
cin>>t;
s.insert(t);
}
cout<<s.size()<<endl;
set<int>::iterator it;
for(it=s.begin();it!=s.end();it++)
cout<<*it<<" ";
return 0;
}