版权声明:本文为博主原创文章,未经博主允许不得转载。如需转载,请与博主联系。 https://blog.csdn.net/qq_31790997/article/details/88910759
【小韦同学@神犇营-my1045-明明的随机数】
题目:
描述
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。
输入
输入有两行,第1行为1个正整数,表示所生成的随机数的个数N
第2行有N个用空格隔开的正整数,为所产生的随机数。
输出
输出也是两行,第1行为1个正整数M,表示不相同的随机数的个数。
第2行为M个用空格隔开的正整数,为从小到大排好序的不相同的随机数。
输入样例1
10
20 40 32 67 40 20 89 300 400 15
输出样例1
8
15 20 32 40 67 89 300 400
题解:
/*********************************************************************
* 题目:神犇营-my1045-明明的随机数
* 作者:小韦同学
* 邮箱:[email protected]
* 题解:
思路:
题目要求去重和升序排列,所以用set容器会非常简单。
定义set容器:set<int> st; // set容器的类型是int,名字是st
将数存到set容器中:st.insert(x); // 将int型的数x存到st这个set容器中
将set容器中的数输出来:
for (set<int>::iterator it = st.begin(); it != st.end(); it++) {
cout << (*it) << " ";
}
注意:
set<int>::iterator it是在定义一个迭代器。(*it)是将迭代器所指向的内容
*********************************************************************/
#include <bits/stdc++.h>
using namespace std;
int main() {
int n;
cin >> n;
int x;
set<int> st; // 定义一个set容器
while (n--) {
cin >> x;
st.insert(x); // 将输入的数放入set容器中
}
// 输出set容器的大小,即不相同的随机数的个数
cout << st.size() << endl;
// 将set容器里面的数输出来,set会将数字从小到大排序
for (set<int>::iterator it = st.begin(); it != st.end(); it++) {
cout << (*it) << " ";
}
return 0;
}
我是小韦同学,企者不立,跨者不行,每天进步一点点。
欢迎大家多多交流,如果发现有错误,请多指正。有疑问的同学也可以留言评论或者发邮件。
邮箱:[email protected]