明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。 输入: 输入2行,第1行为1个正整数,表示所生成的随机数的个数N 第2行有N个用空格隔开的正整数,为所产生的随机数。 输出: 输出2行,第1行为1个正整数M,表示不相同的随机数的个数。第2行为M个用空格隔开的正整数,为从小到大排好序的不相同的随机数。 样例输入: 10 20 40 32 67 40 20 89 300 400 15 样例输出: 8 15 20 32 40 67 89 300 400 。C++代码实现
时间: 2023-11-28 22:49:43 浏览: 110
```c++
#include <iostream>
#include <algorithm>
using namespace std;
const int MAXN = 105;
int n, num[MAXN], newNum[MAXN], ans[MAXN], cnt;
int main() {
cin >> n;
for (int i = 0; i < n; i++) {
cin >> num[i];
}
sort(num, num + n);
for (int i = 0; i < n; i++) {
if (i == 0 || num[i] != num[i - 1]) {
newNum[cnt++] = num[i];
}
}
cout << cnt << endl;
for (int i = 0; i < cnt; i++) {
cout << newNum[i] << " ";
}
return 0;
}
```
相关问题
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了n个1到1000之间的随机整数(n≤1000),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的
选项。然后,他把这些数字写在了纸条上,放进了一个袋子里,准备让同学们抽取纸条填写问卷。请问,他最少需要准备多少个选项?
他最少需要准备n个选项。因为他生成了n个1到100之间的随机整数,对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的选项。所以最少需要准备n个选项,以保证每个数字都有对应的选项。
明明想在学校中请一些同学一起做一项问卷调查
,但是又不知道该如何开始,你会怎么做?
如果我是你,我会先确定调查的主题和目的,然后制定好调查问题和选项。接着,我会找到一些愿意参与调查的同学,并向他们解释调查的目的和意义,以便他们能够积极参与。最后,我会安排好调查的时间和地点,并在调查结束后对结果进行分析和总结。