洛谷 P1059 明明的随机数
题目描述
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了NNN个111到100010001000之间的随机整数(N≤100)(N≤100)(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。
输入输出格式
输入格式:
输入有两行,第111行为111个正整数,表示所生成的随机数的个数NNN
第222行有NNN个用空格隔开的正整数,为所产生的随机数。
输出格式:
输出也是两行,第111行为111个正整数MMM,表示不相同的随机数的个数。
第222行为MMM个用空格隔开的正整数,为从小到大排好序的不相同的随机数。
方法同样有很多
1、调用库函数法
#include<iostream>
#include<algorithm>
using namespace std;
int main(){
int n;
cin>>n;
int a[n];
for(int i=;i<n;i++){
cin>>a[i];
}
sort(a,a+n);
int m;
m = unique(a,a+n) - a;
cout<<m<<endl;
for(int i=;i<m;i++){
cout<<a[i]<<" ";
}
return ;
}
2、巧妙方法
#include<iostream>
using namespace std;
int main(){
int n;
cin>>n;
int a[n];
int b[];
for(int i=;i<;i++){
b[i]=;
}
for(int i=;i<n;i++){
cin>>a[i];
b[a[i]]++;
}
int count=;
for(int i=;i<;i++){
if(b[i]!=) count++;
}
cout<<count<<endl;
for(int i=;i<;i++){
if(b[i]!=) cout<<i<<" ";
}
return ;
}
3、最常规的方法,手动排序手动查重
#include<iostream>
using namespace std;
int main(){
int n;
cin>>n;
int a[n],b[n];
for(int i=;i<n;i++){
cin>>a[i];
}
int temp;
for(int i=;i<n;i++){
for(int j=i+;j<n;j++){
if(a[i]>a[j]){
temp=a[i];a[i]=a[j];a[j]=temp;
}
}
} b[]=a[];
int k=;;
for(int i=;i<n;i++){
if(a[i]!=a[i-]) {
b[k]=a[i];
k++;
}
}
//k++;
cout<<k<<endl;
for(int i=;i<k;i++){
cout<<b[i]<<" ";
} return ;
}
请大佬指点
洛谷 P1059 明明的随机数的更多相关文章
- 【洛谷P1059 明明的随机数】
		
题目描述明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着 ...
 - 洛谷 P1059明明的随机数 & P1068分数线划定 & P1781宇宙总统
		
题目:https://www.luogu.org/problemnew/show/P1059 思路:STL中的set使用. //#include<bits/stdc++.h> #inclu ...
 - 洛谷 P1059【明明的随机数】 题解
		
事实上,完全可以先将输入进来带有重复的元素们保存进一个数组并对该数组进行排序,再将该数组的各个元素逐个判断是否与前一元素相同(重复与否的判断),将不重复的元素转移至另一个数组,与此同时进行对不重复元素 ...
 - P1059 明明的随机数【去重排序】
		
题目描述 明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应 ...
 - BZOJ2875 & 洛谷2044:[NOI2012]随机数生成器——题解
		
https://www.lydsy.com/JudgeOnline/problem.php?id=2875 https://www.luogu.org/problemnew/show/P2044 栋栋 ...
 - 【洛谷 P3306】[SDOI2013]随机数生成器 (BSGS)
		
题目链接 怎么这么多随机数生成器 题意见原题. 很容易想到\(BSGS\)算法,但是递推式是\(X_{i+1}=(aX_i+b)\mod p\),这显然不是一个等比数列. 但是可以用矩阵乘法来求出第\ ...
 - [bzoj1005] [洛谷P2624] 明明的烦恼
		
Description 自从明明学了树的结构,就对奇怪的树产生了兴趣-- 给出标号为1到N的点,以及某些点最终的度数,允许在任意两点间连线,可产生多少棵度数满足要求的树? Input 第一行为N(0 ...
 - NOIP 2006 明明的随机数
		
洛谷 P1059 明明的随机数 洛谷传送门 JDOJ 1423: [NOIP2006]明明的随机数 T1 JDOJ传送门 Description 明明想在学校中请一些同学一起做一项问卷调查,为了实验的 ...
 - 【洛谷2624】[HNOI2008] 明明的烦恼(Python+利用prufer序列结论求解)
		
点此看题面 大致题意: 给你某些点的度数,其余点度数任意,让你求有多少种符合条件的无根树. \(prufer\)序列 一道弱化版的题目:[洛谷2290][HNOI2004] 树的计数. 这同样也是一道 ...
 
随机推荐
- 在centos7上安装DSPC
			
感谢朋友支持本博客.欢迎共同探讨交流,因为能力和时间有限.错误之处在所难免,欢迎指正! 假设转载,请保留作者信息. 博客地址:http://blog.csdn.net/qq_21398167 原博文地 ...
 - Swift和Objective-C混合编程——Swift调用OC
			
在iOS应用的开发中.Swift必将代替OC,两者的趋势是"短期共存,长期代替".但曾经有太多的代码是用OC语言完毕的,而Swift的开发也从 OC中继承了非常多的特性.两者也是有 ...
 - 2014腾讯实习生笔试题——define与typedef
			
2014腾讯实习生笔试(广州站)第26题填空题: #define MAX_NUM 1000+1 int Temp = Max_NUM*10; 则Temp的值为( ) 答案是:1010, 由于宏定义仅仅 ...
 - Java系列之JNDI
			
简单介绍 JNDI(Java Naming and Directory Interface,Java命名和文件夹接口)是SUN公司提供的一种标准的Java命名系统接口.JNDI提供统一的cli ...
 - luogu2278 [HNOI2003]操作系统
			
题目大意 写一个程序来模拟操作系统的进程调度.假设该系统只有一个CPU,每一个进程的到达时间,执行时间和运行优先级都是已知的.其中运行优先级用自然数表示,数字越大,则优先级越高.如果一个进程到达的时候 ...
 - git出错调试
			
https://stackoverflow.com/questions/6178401/how-can-i-debug-git-git-shell-related-problems git_trace ...
 - P1043 数字游戏
			
P1043 数字游戏 题目描述 丁丁最近沉迷于一个数字游戏之中.这个游戏看似简单,但丁丁在研究了许多天之后却发觉原来在简单的规则下想要赢得这个游戏并不那么容易.游戏是这样的,在你面前有一圈整数(一共n ...
 - django自带权限控制系统的使用和分析
			
1.django的权限控制相关表及其相互间的关系: django的所有权限信息存放在auth_permission表中,用户user和用户组group都可以有对应的权限permission.分别存放在 ...
 - XHprof 使用 (转)
			
原文地址:http://blog.csdn.net/maitiandaozi/article/details/8896293 XHProf是facebook开源出来的一个php轻量级的性能分析工具,跟 ...
 - 【IDEA】(4)---很好用的DEBUG功能
			
IDEA-DEBUG功能 一.常用快捷键 快捷键并不是完全一样的,我这边是MAC安装的IDEA, 这边最主要还是知道DEBUG时常用的功能. 1.快捷键 F7 #进入下一步,如果当前行是一个方法,则进 ...