P1059 [NOIP2006 普及组] 明明的随机数

对于这种既需要去重 有需要排序 的数列,我们可以使用 STL 中的 set 容器,它不仅可以去重 ,且还可以排序,正好符合题目标准。

思路

  1. 我们先定义一个 set 容器 st,接着输入 n 个数。提示:输入的 n 个数可以不用数组。
  2. 随后将所有输入的 t 给 insert 进去,此时在 set 容器里的数将自动完成去重排序的任务。
  3. 题目中说明了需要先输出一个数,代表 st 的长度,这时可以用 size 来输出。(size 代表长度)

我们可以用 2 种使用 set 的输出方法:

第一种:

cpp 复制代码
for(auto it:st){
	cout<<it<<' ';
}

第二种:

cpp 复制代码
for(auto it = st.begin();it!=st.end();it++){
	cout<<*it<<' ';	
}

AC CODE:

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
set<int> st;
int main(){
	int n;
	cin>>n;
	for(int i=1;i<=n;i++){
		int t;
		cin>>t;
		st.insert(t); 
	} 
	cout<<st.size()<<endl;
	for(auto it:st){
		cout<<it<<' ';
	}
	return 0;
}

注意:正确代码不是唯一的,也可以用数组模拟去重和排序的过程。

相关推荐
EllinY4 小时前
CF2217E Definitely Larger 题解
c++·笔记·算法·构造
筠筠喵呜喵5 小时前
Linux软件开发性能优化
linux·c++·性能优化
Bruce_kaizy6 小时前
c++ linux环境编程——文件io介绍以及open 、write 、read 三剑客深度详解
linux·服务器·c++·ubuntu·操作系统·文件io
PAK向日葵8 小时前
我用 C++ 写了一个轻量级 Python 虚拟机,刚刚开源
c++·python·开源
玖釉-8 小时前
下一个排列:从字典序到原地算法的完整推导
数据结构·c++·windows·算法
枕星而眠8 小时前
数据结构八大排序详解(一):四大简单排序
c语言·数据结构·c++·后端
努力努力再努力wz9 小时前
【Qt入门系列】:按钮组件全解析:从 QAbstractButton 到快捷键事件、单选与复选机制
c语言·开发语言·数据结构·c++·git·qt·github
yunn_9 小时前
单例模式两种实现方法
开发语言·c++·单例模式
代钦塔拉12 小时前
C++ auto
开发语言·c++
我命由我1234512 小时前
C++ - 面向对象 - 常成员函数
android·java·linux·c语言·开发语言·c++·算法