C语言如何产生一定范围内一定数量的不同随机数

麻烦举出随机产生0到80以内的10不重复的随机数的例子... 麻烦举出随机产生0到80以内的10 不重复的随机数的例子 展开
 我来答
小夏聊生活
高能答主

2019-11-24 · 专注于分享生活知识,热爱生活
小夏聊生活
采纳数:447 获赞数:114608

向TA提问 私信TA
展开全部

源代码如下:

#include <stdio.h>

#include <stdlib.h>

#include <stdbool.h>

#include <unistd.h>

#define a 16807//or 48271

#define m 2147483647

#define q (m/a)

#define r (m%a)

static long int seed = 1;

//return rand long in [1,m]

long int pm_rand(void)

{

long hi = seed / q;

long lo = seed % q;

long tmp = a * lo - r * hi;

if(tmp > 0)

seed = tmp;

else

seed = tmp + m;

return seed;

}

int main(void)

{

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

printf("%ld ",pm_rand());

puts("");

return 0;

}

扩展资料

不指定范围产生随机数的源代码

#include<stdio.h>
#include<stdlib.h>
int main()
{
int i;
for(i=0; i<10; i++) //随机产生10个数。
{
printf("%d\n", rand());
}
return 0;
}

风若远去何人留
推荐于2017-09-20 · 知道合伙人互联网行家
风若远去何人留
知道合伙人互联网行家
采纳数:20412 获赞数:450116
专业C/C++软件开发

向TA提问 私信TA
展开全部

1 C语言产生随机数函数。rand(); 头文件为stdlib.h

2 产生[m,n]范围内随机数的语句: rand()%(n-m+1)+m

3 要产生不同随机数范围的方法:

将已获取的随机数保存下来,在产生新的随机数后,与已获取到的进行比较,如果存在则抛弃,否则保存。


于是,获取到最小为m,最大为n,总数为k个的不同随机数的函数可以写作:

void get_rand(int *a, int m, int n, int k)//结果存在a中
{
    int i,j,t;
    for(i = 0; i < k; )
    {
        t = rand()%(n-m+1)+m;
        for(j = 0; j < i; j ++)
            if(a[j] == t) break;
        if(j == i)//不重复
            a[i++] = t;//记录随机数。
    }
}
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
kaixingui2012
推荐于2017-10-02 · TA获得超过4.2万个赞
知道大有可为答主
回答量:1.4万
采纳率:81%
帮助的人:6327万
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
void main()
{
int a[10];
int i;
srand(time(NULL));
for( i=0;i<10;i++ )
{
int j;
int n=rand()%80;
for( j=0;j<i;j++ )
{
if ( a[j]==n ) {
                i--;
                break;
}
}
if ( j>=i )
a[i]=n;
}
for( i=0;i<10;i++ )
printf("%d ", a[i] );
printf("\n");
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
raef_beyond
2015-05-17 · TA获得超过1651个赞
知道小有建树答主
回答量:382
采纳率:50%
帮助的人:232万
展开全部
我写了以个完整的程序给你参考。
源代码如下(vc++6.0下编译通过):
#include <stdio.h>
#include <stdlib.h>
#include <time.h>

#define RAND_NUM_START 0
#define RAND_NUM_END 80
#define MAX_NUM_LEN 10

int main()
{
int rand_num[MAX_NUM_LEN] = {0};
int count = 0;
int n = 0;
int j = 0;
int flag = 1;

srand((unsigned)time(NULL));

while (count < MAX_NUM_LEN)
{
n = rand()%(RAND_NUM_END - RAND_NUM_START + 1) + RAND_NUM_START;
for (j = 0; j < MAX_NUM_LEN; j++)
{
if (n == rand_num[j])
{
flag=0;
break;
}
else
{
flag = 1;
}
}
if(flag)
{
rand_num[count] = n;
printf("%d\n", rand_num[count]);
count++;
}
}

return 0;
}

希望对你有帮助。
追答
如对你有帮助,请采纳,谢谢!
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
箫韶九成凤凰来仪7
2015-05-16 · TA获得超过378个赞
知道小有建树答主
回答量:394
采纳率:0%
帮助的人:334万
展开全部
mark下明天没人回答我给代码
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式