鱼C论坛

 找回密码
 立即注册
查看: 3737|回复: 13

怎么生成足够大的随机数

[复制链接]
发表于 2019-6-4 09:53:56 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
大家好,我最近做一题要求生成1000000组,每组2个,范围为1到2的31次方的随机数,统计其中互质的组数,然后除以总组数。题目说输出结果约为60.914000%,我写的代码如下,结果总是差很远,我检查了一下,是生成随机数那里出了问题,我看我生成的随机数,最大也就30000多,和我的区间差了很远,请问是为什么?应该怎么改才行呢,谢谢大家了。
  1. #include <iostream>
  2. #include <algorithm>
  3. #include <time.h>
  4. using namespace std;

  5. bool coprime(int m, int n);
  6. int main()
  7. {
  8.         float i;
  9.         float j = 0;

  10.         long long max = pow(2, 31);
  11.         int min = 1;

  12.         for (i = 1; i < 1000000; i++){

  13.                 srand(time(NULL));
  14.                 long long num1 = rand() % (max)+min;
  15.                 long long num2 = rand() % (max)+min;

  16.                 if (coprime(num1, num2))
  17.                 {
  18.                         j++;
  19.                 }
  20.         }

  21.         float c = j / 1000000;

  22.         cout << c * 100 << "%" << endl;

  23.         return 0;
  24. }

  25. bool coprime(int m, int n)
  26. {
  27.         int num1 = m;
  28.         int num2 = n;
  29.         int num3;

  30.         if (num1 == num2)
  31.         {
  32.                 return false;
  33.         }
  34.         else if (num1 < num2)
  35.         {
  36.                 num1 ^= num2;
  37.                 num2 ^= num1;
  38.                 num1 ^= num2;
  39.         }
  40.         else
  41.         {
  42.                 while ((num3 = num1 % num2) != 0)
  43.                 {
  44.                         num1 = num2;
  45.                         num2 = num3;
  46.                 }
  47.                 if (num2 == 1)
  48.                 {
  49.                         return true;
  50.                 }
  51.                 else
  52.                 {
  53.                         return false;
  54.                 }
  55.         }
  56. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2019-6-4 11:46:40 | 显示全部楼层
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>

  4. unsigned long long get_num(void)
  5. {
  6.         size_t group1 = rand() % 2;
  7.         size_t group2 = rand() % 1000;
  8.         size_t group3 = rand() % 1000;
  9.         size_t group4 = rand() % 1000;
  10.         return group1 * 1000000000 + group2 * 1000000 + group3 * 1000 + group4;
  11. }

  12. int main(void)
  13. {
  14.         srand(time(NULL));
  15.         for(size_t i = 0; i < 10; ++i)
  16.                 printf("%-10llu ", get_num());
  17.         printf("\n");
  18.         return 0;
  19. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-4 12:13:44 | 显示全部楼层

谢谢您的回答,我能问您一下是详细原因吗?我的那种方法为什么产生不了足够大的数字。
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 12:21:01 | 显示全部楼层
在标准的C库中函数rand()可以生成0~RAND_MAX之间的一个随机数
ISO IEC 9899 2011 (C11)标准中未规定 RAND_MAX 的具体数值。但该标准规定了RAND_MAX 的值应至少为32767。编程的时候,不应该对 RAND_MAX 的具体数值做任何假设。

https://baike.so.com/doc/6691467-6905373.html
https://baike.so.com/doc/5429498-5667743.html
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 12:38:58 | 显示全部楼层
还有一个问题
下面这两个代码有区别吗?
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>

  4. int main(void)
  5. {
  6.         for(size_t i = 0; i < 10; ++i)
  7.         {
  8.                 srand(time(NULL));
  9.                 printf("%d\n", rand());
  10.         }
  11.         return 0;
  12. }
复制代码

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>

  4. int main(void)
  5. {
  6.         srand(time(NULL));
  7.         for(size_t i = 0; i < 10; ++i)
  8.         {
  9.                 printf("%d\n", rand());
  10.         }
  11.         return 0;
  12. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 12:39:56 | 显示全部楼层
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>

  4. int main(void)
  5. {
  6.         for(size_t i = 0; i < 10; ++i)
  7.         {
  8.                 srand(time(NULL));
  9.                 printf("%d\n", rand());
  10.         }
  11.         return 0;
  12. }
复制代码

  1. sh-4.4$ gcc -g -Wall -o main main.c
  2. sh-4.4$ ./main
  3. 1639720720
  4. 1639720720
  5. 1639720720
  6. 1639720720
  7. 1639720720
  8. 1639720720
  9. 1639720720
  10. 1639720720
  11. 1639720720
  12. 1639720720
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 12:40:30 | 显示全部楼层
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>

  4. int main(void)
  5. {
  6.         srand(time(NULL));
  7.         for(size_t i = 0; i < 10; ++i)
  8.         {
  9.                 printf("%d\n", rand());
  10.         }
  11.         return 0;
  12. }
复制代码

  1. sh-4.4$ gcc -g -Wall -o main main.c
  2. sh-4.4$ ./main
  3. 888289819
  4. 1525689850
  5. 753208532
  6. 926527887
  7. 1333579581
  8. 164749365
  9. 635877355
  10. 1509412444
  11. 368207771
  12. 2000500888
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 12:43:17 | 显示全部楼层
文字被和谐了,贴图片
1.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-4 17:04:02 | 显示全部楼层

您好,我又想了一下,这个好像不能产生符合我要求的随机数,您的这个区间好像比我的要小
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 17:21:12 | 显示全部楼层
本帖最后由 Croper 于 2019-6-4 17:26 编辑
人造人 发表于 2019-6-4 12:38
还有一个问题
下面这两个代码有区别吗?

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>

  4. int main(void)
  5. {
  6.         for(size_t i = 0; i < 10; ++i)
  7.         {
  8.                 srand(time(NULL));
  9.                 printf("%d\n", rand());
  10.         }
  11.         return 0;
  12. }
复制代码
话说time(null)返回的不是1970年到现在的秒么。。你这段代码肯定执行时间不到一秒吧,那srand了同一个值。。。rand()不就完全一样了么-
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 17:35:22 | 显示全部楼层
Gerton 发表于 2019-6-4 17:04
您好,我又想了一下,这个好像不能产生符合我要求的随机数,您的这个区间好像比我的要小

知道原理了自己改下不就行了
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 21:55:53 | 显示全部楼层
Croper 发表于 2019-6-4 17:21
话说time(null)返回的不是1970年到现在的秒么。。你这段代码肯定执行时间不到一秒吧,那srand了同一个 ...

嗯,这个问题我知道答案,我是在问他,因为他把srand和rand放在了一个循环中

1.png
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-6-4 22:03:44 | 显示全部楼层
Gerton 发表于 2019-6-4 17:04
您好,我又想了一下,这个好像不能产生符合我要求的随机数,您的这个区间好像比我的要小

现在呢?

  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <time.h>
  4. #include <math.h>

  5. unsigned long long get_num(void)
  6. {
  7.         long long max = pow(2, 31);
  8.         long long result;

  9.         do
  10.         {
  11.                 size_t group1 = rand() % 3;
  12.                 size_t group2 = rand() % 1000;
  13.                 size_t group3 = rand() % 1000;
  14.                 size_t group4 = rand() % 1000;
  15.                 result = group1 * 1000000000 + group2 * 1000000 + group3 * 1000 + group4;
  16.         }
  17.         while(result >= max);
  18.         return result;
  19. }

  20. int main(void)
  21. {
  22.         srand(time(NULL));
  23.         for(size_t i = 0; i < 10; ++i)
  24.                 printf("%-10llu ", get_num());
  25.         printf("\n");
  26.         return 0;
  27. }
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2019-6-20 08:57:03 | 显示全部楼层
人造人 发表于 2019-6-4 21:55
嗯,这个问题我知道答案,我是在问他,因为他把srand和rand放在了一个循环中

是的诶,看来我没弄明白这个的意思,谢谢您
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-7-12 22:36

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表