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;
}

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

相关推荐
MC皮蛋侠客12 分钟前
Perf 火焰图深度实战:CPU 性能分析与异常排查完全指南
linux·c++·性能分析·perf·火焰图
熊孩纸的世界你不懂25 分钟前
Qt + SQLite 配置与使用指南
c++·qt
码上有光39 分钟前
c++模板进阶知识讲解(对模板的进一步的运用与理解)
java·前端·c++·特化·模板进阶·偏特化
Zhang~Ling1 小时前
C++ 继承机制详解下:多继承、虚继承与菱形继承底层原理
开发语言·c++·算法
思麟呀1 小时前
C++工业级日志项目(四)日志落地
linux·开发语言·c++·windows
哼?~1 小时前
C++11 并发支持库中 atomic
c++
玖釉-1 小时前
单词搜索:二维网格中的 DFS 回溯与剪枝优化
c++·windows·算法·深度优先·剪枝
吴可可1231 小时前
C++与C#版Teigha样条离散化差异解析
c++·算法·c#
搬砖的小码农_Sky1 小时前
macOS Sequoia上如何安装gcc/g++环境?
c语言·c++·macos
MC皮蛋侠客1 小时前
C++17 多线程系列(二):共享数据与同步——mutex 与 condition_variable
开发语言·c++·多线程