当前位置: 首页 > news >正文

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

题目描述

明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了 N 个 1 到 1000 之间的随机整数 (N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。

输入格式

输入有两行,第 11 行为 11 个正整数,表示所生成的随机数的个数 �N。

第 22 行有 �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

说明/提示

NOIP 2006 普及组 第一题

思路 

 把每个输入的数其对应的数组下标的位置变成一,再遍历一遍这个数组,把下标是1的位置输出即可.

AC代码 

#include <bits/stdc++.h>using namespace std;int n,m,p,maxp=-1;
int s[1000000]={0};int main()
{cin>>n;for(int i=1;i<=n;i++){cin>>p;if(s[p]<1){m++;s[p]=1;     //对应数组位置变成1}maxp=max(maxp,p);   //找最大数}cout<<m<<endl;for(int i=1;i<=maxp;i++){if(s[i]==1){cout<<i<<" ";}}return 0;
}

 

http://www.lryc.cn/news/313665.html

相关文章:

  • 【每日一问】Cookie、Session 和 Token 有什么区别?
  • 智能合约语言(eDSL)—— proc_macro实现合约init函数
  • 如何使用 ArcGIS Pro 制作三维地形图
  • 服务器配置禁止IP直接访问,只允许域名访问
  • #14vue3生成表单并跳转到外部地址的方式
  • 航测管家:智能化革新航测作业流程
  • XXE-XML实体注入漏洞
  • 数据结构从入门到精通——栈
  • webhook详解
  • 用 ChatGPT 帮自己修英文简历 — UI/UX 设计师篇
  • 2402. 2-SAT 问题(tarjan,2-SAT模板题)
  • 基于java+springboot+vue实现的宠物健康咨询系统(文末源码+Lw)23-206
  • 品牌如何玩转饥饿营销?媒介盒子分享
  • Vue3:ref和reactive实现响应式数据
  • 二维码门楼牌管理系统应用场景:商业与零售业发展的助推器
  • 【Linux进阶之路】网络 —— “?“ (下)
  • 【AIGC】Stable Diffusion的建模思想、训练预测方式快速
  • JVM(类加载机制)
  • C++ 实战项目之 Boost 搜索引擎
  • 部署LVS+Keepalived高可用群集(抢占模式,非抢占模式,延迟模式)
  • 性别和年龄的视频实时监测项目
  • 【Spring面试题】
  • 打车代驾小程序开发 醉酒不用怕一键找代驾
  • 蓝桥集训之统计子矩阵
  • 架构师十项全能 你会几个?
  • 数据库(mysql)-新手笔记(主外键,视图)
  • 西门子PLC的交互界面怎样设计?
  • 备份 ChatGPT 的聊天纪录
  • 支持向量机 SVM | 线性可分:软间隔模型
  • 基于Java的生活废品回收系统(Vue.js+SpringBoot)