**明明的随机数**
明明想在学校中请一些同学一起做一项问卷调查,为了实验的客观性,他先用计算机生成了N个1到1000之间的随机整数(N≤100),对于其中重复的数字,只保留一个,把其余相同的数去掉,不同的数对应着不同的学生的学号。然后再把这些数从小到大排序,按照排好的顺序去找同学做调查。请你协助明明完成“去重”与“排序”的工作。
做法:桶排序,很简单直白。。
代码如下(C):
#include <cstdio>
using namespace std;
bool f[1000];
int main()
{
int n,x;
scanf("%d",&n);
for (int i=1;i<=n;i++)
{
scanf("%d",&x);
f[x]=1;
}
n=0;
for (int i=1;i<=1000;i++)
if (f[i]==1) n++;
printf("%d\n",n);
for (int i=1;i<=1000;i++)
if (f[i]==1) printf("%d ",i);
}
本文介绍了一种使用桶排序进行随机数去重和排序的方法,以帮助明明在学校进行问卷调查时选择不同学号的学生。通过C语言实现,首先生成一系列随机数,然后去除重复数字并按升序排列。
476

被折叠的 条评论
为什么被折叠?



