你好,怎样用c语言输出一个1到100的随机数

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了你好,怎样用c语言输出一个1到100的随机数相关的知识,希望对你有一定的参考价值。

参考技术A

你好,怎样用c语言输出一个1到100的随机数

include <stdio.h>
#include<time.h>
#include<stdlib.h>
main()

int i;
srand(time(0));
i=rand()%100+1;/*随机函数*/
printf("%d",i);。

C语言怎样输出一组随机数据

嗯~
代码诠释一下
#include <stdio.h>
#include <time.h>
#include <stdlib.h>
#define N 10
main()

int a[N],i,j;
srand(time(NULL));
for(i=0;i<N;i++)

do

a[i]=rand()%100+1;随机数
for(j=0;j<i;j++)
if(a[j]==a[i])
break;
while(j<i);

for(i=0;i<10;i++)
printf("%4d",a[i]);

用c语言出一个随机数,怎么编

你说产生一个随即数,还是产生很多随即数,然后排序?然后还要查找?查找什么数?题目说清楚ok?
产生50个随即数,然后排序可以办到,那么查找显示出什么数?
根据你的要求题意,程序如下,运行正常。
#include<stdio.h>
#include<stdlib.h>
#include<time.h>
main()

int a[50];
int i,j,k,temp,n;
srand(time(0)); /* 设置种子 */
for(i=0;i<50;i++)
a[i]=rand(); /* 随机产生50个数 */
for(i=0;i<49;i++) /* 排序 */

k=i;
for(j=i+1;j<50;j++)
if(a[j]<a[k])k=j;
temp=a[k];
a[k]=a[i];
a[i]=temp;

printf("50个随机数经排序后为:\\n");
for(i=0;i<50;i++)
printf("%d,",a[i]);
printf("\\n");
printf("请在这50个数中指定一个数:\\n");
scanf("%d",&n);
for(i=0;i<50;i++)
if(a[i]==n)break;
printf("这个数是第%d个元素\\n",i+1);
getch();

另外,站长团上有产品团购,便宜有保证

C语言中如何同时输出100个随机数

#include <stdio.h>
#include <time.h>
#include <stdlib.h>
int main()

srand(time(NULL));
for (int i=0;i<=50;i++)

int a=rand()%1000;
int b=rand()%10000;
printf("%d,%d\\n",a,b) ;
return 0;

怎样用c语言生成n个随机数

产生一定范围随机数的通用表示公式
要取得[a,b)的随机整数,使用(rand() % (b-a))+ a;
要取得[a,b]的随机整数,使用(rand() % (b-a+1))+ a;
要取得(a,b]的随机整数,使用(rand() % (b-a))+ a + 1;
通用公式:a + rand() % n;其中的a是起始值,n是整数的范围。
要取得a到b之间的随机整数,另一种表示:a + (int)b * rand() / (RAND_MAX + 1)。
要取得0~1之间的浮点数,可以使用rand() / double(RAND_MAX)。

C语言中怎样把随机数表打乱?我输一组随机数(用rand函数),但是每次运行只输出一个值。怎么办?

呵呵,上面两位的回答都很标准,但是,为了不让你在该给谁分上太难取舍,我还是给更标准的回答吧,让你更好理解 首先想要让计算机模拟随机事件是一件很难很难的事情,因为计算机最大的优点就是守规矩,你想让计算机模拟无规律的随机数生成从本质上甚至是不可实现,通常情况下,我们所说的随机数的输出,仅仅是让计算机获取一切信息,然后根据一连串的算法输出看似随机的数。 如果一个算法依赖的信息够大,且够复杂,人力甚至是机器都难以猜出其中的规律,我们就说输出的数是随机的 同理,你在程序里设计里犯的错误就在于没有一个信息获得的渠道,使计算机空有算法却无法根据信息来计算,输出 一般的,我们以计算机运行的时间来作为随机算法的信息来源,因为时间不会倒退,更不会重复,可以比较好的模拟随机 前面两位所说的种子也就是以时间作为基准,用RAND()函数的算法加工之后再输出数字,来模拟随机数的生成 现给出两种可行的写法,均是输出10个100以内的随机数 #include<stdlib.h> int i=0; randomize(); for(i=0;i<10;i++) printf("%d\\t",random(100)); #include<stdlib.h> #include<time.h> main() int i; srand(time(NULL)); for(i=0;i<10;i++) printf("%d\\t",rand()%100); 你可以自己揣摩其中的区别

怎样用C语言生成10个1到100的不重复的随机数?

/*
7 29 89 2 63 35 34 82 96 87 69 6 44 12 5 93 4 67 46 83
Press any key to continue
*/
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define N 20
int main()
int i,j,flag,num,a[N];
srand((unsigned)time(NULL));
for(i = 0; i < N; ++i)
num = rand()%98 + 1;
flag = 1;
for(j = 0; j < i; ++j)
if(num == a[j])
flag = 0;;
break;


if(flag) a[i] = num;
else --i;

for(i = 0; i < N; ++i)
printf("%d ",a[i]);
printf("\\n");
return 0;

c语言 产生一个1~50的随机数

#include<stdio.h>
#include<stdlib.h>
#include<time.h>
void main()

int i,temp,tag=1;
srand((unsigned)time(NULL)); /*使随机数不一样*/
while(tag==1)

temp=rand(); /*产生随机数*/
if(temp>0&&temp<51)

i=temp;
printf("i为%d。\\n是否退出?1.是;2.否。请选择:",i); /*判断是否结束循环*/
scanf("%d",&temp);
if(temp==1)
tag=0;


怎样用java语言编程实现输出一个由10个随机数组成的数组

import java.util.Random;
public class text

public static void main(String[] args)

int[] num = new int[10];
int i;

for(i=0;i<10;i++)

Random r = new Random();
num[i] = 1 + r.nextInt(100);
System.out.print(" "+num[i]);


C语言怎样产生一定范围的随机数?

现在需要产生1~3之间的整型随机数,该用什么函数产生?百度上面没找到产生随机数的范围最小值大于0的方法,rand,srand怎么用才能产生任意范围的整型随机数?
在线等待中~~~~

编译环境为:vs2013
产生1到3的整型随机数的代码如下:
#include<stdio.h>
#include<time.h>
#include<stdlib.h>
#define max 3   //这个函数的意义为:随机生成最大的数为3
#define min 1    //这个函数的意义为:随机生成最小的数为1
int main()

int num;
srand(time(0));
num = rand() % (max - min) + min;  // 这里的意义,“%”为模运算
printf("随机数为:%d\\n", num);
system("pause");  //这个代码可以让弹出的黑框不会一下就消失
return 0;

扩展资料:

根据密码学原理,随机数的随机性检验可以分为三个标准: 

条件一、统计学伪随机性。统计学伪随机性指的是在给定的随机比特流样本中,1的数量大致等于0的数量,同理,“10”“01”“00”“11”四者数量大致相等。类似的标准被称为统计学随机性。满足这类要求的数字在人类“一眼看上去”是随机的。

条件二、密码学安全伪随机性。其定义为,给定随机样本的一部分和随机算法,不能有效的演算出随机样本的剩余部分。

条件三、真随机性。其定义为随机样本不可重现。实际上只要给定边界条件,真随机数并不存在,可是如果产生一个真随机数样本的边界条件十分复杂且难以捕捉(比如计算机当地的本底辐射波动值),可以认为用这个方法演算出来了真随机数。

随机数分为三类:

①伪随机数:满足第一个条件的随机数。

②密码学安全的伪随机数:同时满足前两个条件的随机数。可以通过密码学安全伪随机数生成器

计算得出。

③真随机数:同时满足三个条件的随机数。



参考技术A

在C语言中,rand()函数可以用来产生随机数,但是这不是真真意义上的随机数,是一个伪随机数,是根据一个数,可以称它为种子。

为基准以某个递推公式推算出来的一系数,当这系列数很大的时候,就符合正态公布,从而相当于产生了随机数。

C语言产生一定范围的随机数的源代码如下:

#include<stdio.h>

#include<stdlib.h>

int main()

int i;

for(i=0; i<10; i++) //随机产生10个数。

printf("%d\\n", rand());

return 0;

扩展资料

1、如果要随机生成一个在一定范围的数,你可以在宏定义中定义一个random(int number)函数,然后在main()里面直接调用random()函数。

2、在对rand()的前三次调用中,并且此后得到的返回值仍然是在对rand()的第一批调用中所得到的其余的返回值。因此,只有再次给srand()提供一个随机的“种子”值,才能再次得到一个随机数。

参考技术B

利用srand((unsigned int)(time(NULL))是一种方法,因为每一次运行程序的时间是不同的。

在C语言里所提供的随机数发生器的用法:现在的C编译器都提供了一个基于ANSI标准的伪随机数发生器函数,用来生成随机数。它们就是rand()和srand()函数。这二个函数的工作过程如下:

1) 首先给srand()提供一个种子,它是一个unsigned int类型,其取值范围从0~65535;

2) 然后调用rand(),它会根据提供给srand()的种子值返回一个随机数(在0到32767之间)

3) 根据需要多次调用rand(),从而不间断地得到新的随机数;

4) 无论什么时候,都可以给srand()提供一个新的种子,从而进一步“随机化”rand()的输出结果。

下面是0~32767之间的随机数程序:

#include <stdlib.h>

#include <stdio.h>

#include <time.h>           // 使用当前时钟做种子

void main(void)

int i;

srand((unsigned)time( NULL ) );          // 初始化随机数

for(i = 0; i < 10;i++)                          // 打印出 10 个随机数

printf("%d\\n", rand() );

根据上面的程序可以很容易得到0~1之间的随机数:

#include <stdlib.h>

#include <stdio.h>

#include <time.h> 

int main( )

int i;

srand((unsigned)time( NULL ) );  

for(i = 0; i < 10;i++)

printf("%5.2f\\n", rand()/32767.0);

而产生1~100之间的随机数可以这样写:

#include <stdlib.h>

#include <stdio.h>

#include <time.h> 

int main( )

int i;

srand((unsigned)time( NULL ) );  

for(i = 0; i < 10;i++)

printf("%d\\n", rand()%100+1);

扩展资料:

C语言高效编程技巧:

一:以空间换时间

计算机程序中最大的矛盾是空间和时间的矛盾,那么,从这个角度出发逆向思维来考虑程序的效率问题

二:数学方法解决问题 

数学是计算机之母,没有数学的依据和基础,就没有计算机发展,所以在编写程序的时候,采用一些数学方法会对程序的执行效率有数量级的提高。

三:使用位操作

实现高效的C语言编写的第三招----使用位操作,减少除法和取模的运算。

在计算机程序中,数据的位是可以操作的最小数据单位,理论上可以用“位运算”来完成所有的运算和操作。一般的位操作是用来控制硬件的,或者做数据变换使用,但是,灵活的位操作可以有效提高程序运行的效率。

参考资料来源:百度百科-C语言

参考技术C

在C语言中,rand()函数可以用来产生随机数,但是这不是真真意义上的随机数,是一个伪随机数,是根据一个数,可以称它为种子。

为基准以某个递推公式推算出来的一系数,当这系列数很大的时候,就符合正态公布,从而相当于产生了随机数。

C语言产生一定范围的随机数的源代码如下:

#include<stdio.h>

#include<stdlib.h>

int main()

int i;

for(i=0; i<10; i++) //随机产生10个数。

printf("%d\\n", rand());

return 0;

参考技术D srand((int)time(NULL));设定随机数种子
rand()%100;产生0-99的随机数。高级点的,假如要产生16-59之间的数,你可以这样写:rand()%44+16(这里44由59-16+1得到)。其他情况如法炮制!

下面是搜回来的:

问题1: 怎样获得一个真正的随机数?要知道,rand()是不能产生真正的随机数的!即使不能产生真正的随机数,也要大概接近呀!而rand()好象每次的随机都一样。

专家解答:

之所以rand()每次的随机数都一样是因为rand()函数使用不正确。各种编程语言返回的随机数(确切地说是伪随机数)实际上都是根据递推公式计算的一组数值,当序列足够长,这组数值近似满足均匀分布。如果计算伪随机序列的初始数值(称为种子)相同,则计算出来的伪随机序列就是完全相同的。这个特性被有的软件利用于加密和解密。加密时,可以用某个种子数生成一个伪随机序列并对数据进行处理;解密时,再利用种子数生成一个伪随机序列并对加密数据进行还原。这样,对于不知道种子数的人要想解密就需要多费些事了。当然,这种完全相同的序列对于你来说是非常糟糕的。要解决这个问题,需要在每次产生随机序列前,先指定不同的种子,这样计算出来的随机序列就不会完全相同了。你可以在调用rand()函数之前调用srand( (unsigned)time( NULL ) ),这样以time函数值(即当前时间)作为种子数,因为两次调用rand函数的时间通常是不同的,这样就可以保证随机性了。你也可以使用srand函数来人为指定种子数。Windows 9x/NT的游戏FreeCell就允许用户指定种子数,这样用户如果一次游戏没有成功,下次还可以以同样的发牌结果再玩一次。

问题2: 我按照上述方法并不能产生随机数,仅产生公差为3或4的等差数列:
#include <stdlib.h>
#include <iostream.h>
#include <conio.h>
#include <time.h>
void main()

for(int i=0;i<100000;i++)

srand( (unsigned)time( NULL ) );
cout<<rand()<<endl;


专家解答:
你的程序是有问题的,你每产生一个随机数之前,都调用一次srand,而由于计算机运行很快,所以你每次用time得到的时间都是一样的(time的时间精度较低,只有55ms)。这样相当于使用同一个种子产生随机序列,所以产生的随机数总是相同的。你应该把srand放在循环外:
srand( (unsigned)time( NULL ) );
for(int i=0;i<100000;i++)

//相关语句


参考资料:http://www.china-askpro.com/msg22/qa36.shtml
请采纳答案,支持我一下。本回答被提问者采纳

以上是关于你好,怎样用c语言输出一个1到100的随机数的主要内容,如果未能解决你的问题,请参考以下文章

怎样用c语言产生0-100随机数?求助高手

怎样在单片机C语言里面产生一个0到100的随机数

C语言 编一个程序,产生0-100随机数,然后用选择排序法,从小到大排列

C语言随机函数:用0到9这10位数随机输出4位.输出100次后停止...

C语言怎样产生一定范围的随机数?

c语言里,想产生0到100之间的一个随机数赋值给i,请问怎么写?