洛谷:明明的随机数,C语言

article/2025/9/17 10:08:54

题目描述

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

输入格式

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

第2行有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 普及组 第一题

思路:

使用桶排序算法

桶排序就是一排带有序列编号的的桶,而这编号的范围就是将我们要排序数据包括在内。在我们输入数据时会在与输入数据相同编号的桶上标记一次,每次输入数据都在与数据相同编号的桶上标记一次,这样每个数据出现的次数就显而易见了,同时也排好序了,我们通过cnt计数,只要标记不为 0,cnt 就 +1,这样就得到了不相同的随机数的个数,再通过判断,从 i=1 开始(随机数N>=1),只要标记不为 0,就输出 i.

关于桶排序:

该题思路来源:

https://www.cnblogs.com/notfound/p/8407171.htmlhttps://www.cnblogs.com/notfound/p/8407171.html

简单易懂版原理:

漫画:什么是桶排序?_CSDN 程序人生的博客-CSDN博客点击上方“程序人生”,选择“置顶公众号”第一时间关注程序猿(媛)身边的故事作者小灰已获原作者授权,如需转载,请联系原作者。————— 第二天 ————————————...https://blog.csdn.net/csdnsevenn/article/details/83218431?ops_request_misc=%257B%2522request%255Fid%2522%253A%2522164922338116781683978496%2522%252C%2522scm%2522%253A%252220140713.130102334.pc%255Fall.%2522%257D&request_id=164922338116781683978496&biz_id=0&utm_medium=distribute.pc_search_result.none-task-blog-2~all~first_rank_ecpm_v1~rank_v31_ecpm-1-83218431.142%5Ev5%5Epc_search_result_cache,157%5Ev4%5Econtrol&utm_term=%E6%A1%B6%E6%8E%92%E5%BA%8F&spm=1018.2226.3001.4187

该题代码:

#include<stdio.h>
#include<string.h>
#define N 1010int arr[N];int main()
{int n,num,i,cnt=0;memset(arr,0,sizeof(arr));scanf("%d",&n);while(n--){scanf("%d",&num);arr[num] ++;//标记}for(i=0;i<=1000;i++)if(arr[i])cnt++;//只要arr[i]不为0,长度+1printf("%d\n",cnt);for(i=0;i<=1000;i++)if(arr[i])//只要arr[i]不为0,就输出iprintf("%d ",i);return 0;
}

http://chatgpt.dhexx.cn/article/tZI9sr80.shtml

相关文章

产生正态分布(高斯分布)随机数 C语言实现

正态分布的概率密度函数如下 通常使用表示均值为,方差为 产生正太分布的方法如下&#xff1a; 设为&#xff08;0&#xff0c;1&#xff09;上n个相互独立的均匀分布的随机数&#xff0c;由于,. 根据中心极限定理可知&#xff0c;当n趋向于无穷时 的分布近似于正态分布&…

产生指数分布的随机数 C语言实现

一、产生随机变量的逆变换方法 定理&#xff1a;设F(x)是任一连续的分布函数&#xff0c;如果&#xff0c;且那么. 证明 由于,则有 所以 此定理给出了从均匀分布随机数到给定分布的随机数的变换&#xff0c;根据该变换可以生分布函数为的随机数&#xff0c;其算法可以用下列…

C语言如何设置随机数

步骤 设置一个随机的起点 那如何设置呢&#xff1f;编写代码srand((unsigned int)time(NULL))。而该代码用到了两个库函数void srand(unsigned int seed)和longlong time(NULL)&#xff0c;对应的头文件是<stdlib.h>和<time.h>。生成随机数 生成随机数直接编写代码…

C语言基础教程:C语言随机函数

1. 随机数概述 编写程序过程中&#xff0c;我们经常需要产生一些随机数。随机数在程序中分为两种&#xff1a; 真随机数&#xff1a;完全没有规则&#xff0c;无法预测接下来要产生的数。伪随机数&#xff1a;通过一些预先设定好的规则产生不能简单预测的数。当然&#xff0c…

C语言头文件深入理解

C语言程序中&#xff0c;源文件通常分为两种&#xff1a;一种用于保存程序的声明(declaration)&#xff0c;称为头文件&#xff1b;另一种用于保存程序的实现(implementation)&#xff0c;称为定义(definition)文件。 C程序的头文件以“.h”为后缀&#xff0c;C 程序的定义文件…

第十四章 C语言头文件的编写_C语言模块化编程中的头文件

前面我们在演示多文件编程时创建了 main.c 和 module.c 两个源文件&#xff0c;并在 module.c 中定义了一个函数和一个全局变量&#xff0c;然后在 main.c 中进行了声明。 不过实际开发中很少这样做&#xff0c;一般是将函数和变量的声明放到头文件&#xff0c;再在当前源文件中…

C语言头文件路径相关问题总结说明

聊聊系统路径位置&#xff0c;绝对路径与相对路径&#xff0c;正斜杠 / 与 反斜杠 \ 使用说明 ...... by 矜辰所致目录 前言一、C语言中的头文件引用二、KEIL 中的头文件路径2.1 IncudePaths 指定的路径绝对路径和相对路径正斜杠 / 与 反斜杠 \ 与双斜杠 2.2 include < &…

c语言头文件下载大全,求C语言头文件下载?

传统 C++ #include <assert.h> //设定插入点 #include <ctype.h> //字符处理 #include <errno.h> //定义错误码 #include <float.h> //浮点数处理 #include <fstream.h> //文件输入/输出 #include <iomanip.h> //参数化输入/输出 #inclu…

python读取C语言头文件

本文测试过程使用使用的工程代码上传 python读取C语言头文件&#xff0c;参考博客&#xff0c;有测试记录、使用说明资源-CSDN文库 或者 python读取C语言头文件测试用例&#xff0c;参考博客&#xff0c;有详细说明-嵌入式文档类资源-CSDN文库 背景 在使用python编程过程中…

c语言中头文件及其作用,C语言头文件的作用是什么

C语言头文件的作用&#xff1a;1、头文件是程序各部分之间保证信息一致性的桥梁&#xff0c;是连接程序对象定义和使用的纽带&#xff1b;2、用于指定模块接口的声明放在文件中&#xff0c;文件名中应标明其预期用途。 本文操作环境&#xff1a;Windows7系统&#xff0c;宏基S4…

c语言头文件编写

使用头文件的作用&#xff1a;当前.c文件要使用其它.c文件已定义的全局函数/全局变量时&#xff0c;对使用的全局函数/全局变量进行声明。 文件包含&#xff1a;文件包含语句的功能是把指定的文件插入该语句行位置&#xff0c;从而把指定的文件和当前的源程序文件连成一个源文件…

编写C语言头文件

C语言头文件 我们写c语言代码的第一步总是#include … 这就是引入头文件。#include 命令是预处理命令的一种&#xff0c;预处理命令可以将别的源代码内容插入到所指定的位置&#xff1b;可以标识出只有在特定条件下才会被编译的某一段程序代码&#xff1b;可以定义类似标识符功…

【C语言】头文件书写方法与规范、code::black中如何创建并编写头文件(一看就会)

目录 其他编译器用户&#xff0c;可以直接跳过标题1&#xff0c;看2.头文件编写注意事项&#xff0c;下面有跳转链接&#xff1a; 1.C::B中创建头文件&#xff1a; 2.头文件编写注意事项 3.C语言常见问题推荐链接 1.C::B中创建头文件&#xff1a; file -> new -> fi…

C语言头文件详解

1、include的作用 简单一句话&#xff1a;在include的地方&#xff0c;把头文件里的内容原封不动的复制到引用该头文件的地方。 2、头文件的引用 头文件引用有两种形式&#xff1a;#include < stdio.h> 和 include "main.h “。 用< >引用的一般是编译器提供的…

C++——友元

友元概述 在讲述类的内容时说明了隐藏数据成员的好处&#xff0c;但是有些时候&#xff0c;类会允许有一些特殊的函数直接读写其私有数据成员。 使用friend关键字可以让特定的函数或者别的类的所有成员函数对私有数据成员进行读写。这既可以保持数据的私有性&#xff0c;又能够…

C++之友元函数

目录 1.定义&#xff1a; 1.概念&#xff1a; 2.注意 3.友元的分类&#xff1a; 4.友元函数代码分析&#xff1a; 1.友元函数出现的原因&#xff08;外部函数友元为例&#xff09;&#xff1a; 2.一个外部函数作为多个类的友元函数 3.成员函数友元&#xff1a; 4.类友…

友元 基础详解版 (友元函数、友元类、友元非成员函数和友元成员函数)

友元 一般来说&#xff0c;类的公有成员能够在类外访问&#xff0c;私有的成员只能被类的其他成员函数访问。 在C中&#xff0c;可以定义友元&#xff0c;如果某一个函数定义为类的友元&#xff0c;则该函数就可以访问该类的私有函数。也可以把一个类定义为另一个类的友元。 …

win7快捷方式去箭头_win7旗舰版桌面图标快捷方式箭头变成黑块怎么办?

大家在使用win7的过程中&#xff0c;发现桌面图标快捷方式箭头变成黑块&#xff0c;这时我们应该怎么解决呢&#xff0c;请继续往下看&#xff01; 操作过程&#xff1a; 1、在winr调出运行窗口&#xff0c;键入regedit.exe&#xff0c;回车&#xff0c;打开注册表编辑器。 依次…

去掉桌面快捷方式箭头和快捷方式字样--美化桌面快捷方式

去掉桌面快捷方式箭头和快捷方式字样--美化桌面快捷方式&#xff0c;如图&#xff1a; 下载地址&#xff1a; https://download.csdn.net/download/lhyhr/12700649

恢复Windows7快捷方式小箭头的方法

电脑重新安装了一个Windows7的纯净版系统&#xff0c;结果快捷方式的小箭头不见了。在网上查到的各种修改注册表的方式都试过之后&#xff0c;依然无效。 后来看到有人介绍可以使用软件恢复&#xff0c;于是下载了一个软件&#xff1a;Windows快捷方式小箭头管理&#xff0c;结…