2415: 【入门】【P1059】明明的随机数(1765)

内存限制:128 MB 时间限制:1.000 S
评测方式:文本比较 命题人:
提交:38 解决:28

题目描述

明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了 lns="http://www.w3.org/1998/Math/MathML"> 个 lns="http://www.w3.org/1998/Math/MathML">1 到 lns="http://www.w3.org/1998/Math/MathML">1000 之间的随机整数 lns="http://www.w3.org/1998/Math/MathML">(100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。

输入

输入有两行,第 lns="http://www.w3.org/1998/Math/MathML">1 行为 lns="http://www.w3.org/1998/Math/MathML">1 个正整数,表示所生成的随机数的个数 lns="http://www.w3.org/1998/Math/MathML">

第 lns="http://www.w3.org/1998/Math/MathML">2 行有 lns="http://www.w3.org/1998/Math/MathML"> 个用空格隔开的正整数,为所产生的随机数。

输出

输出也是两行,第 lns="http://www.w3.org/1998/Math/MathML">1 行为 lns="http://www.w3.org/1998/Math/MathML">1 个正整数 lns="http://www.w3.org/1998/Math/MathML">,表示不相同的随机数的个数。

第 lns="http://www.w3.org/1998/Math/MathML">2 行为 lns="http://www.w3.org/1998/Math/MathML"> 个用空格隔开的正整数,为从小到大排好序的不相同的随机数。

样例输入 复制

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);
    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] <<' '; 
    /***
    方法二:
    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<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;
}