神犇营-my1045-明明的随机数

版权声明:本文为博主原创文章,未经博主允许不得转载。如需转载,请与博主联系。 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]

猜你喜欢

转载自blog.csdn.net/qq_31790997/article/details/88910759