鱼C论坛

 找回密码
 立即注册
查看: 1095|回复: 2

[已解决]随机数问题求解

[复制链接]
发表于 2020-3-9 12:24:07 | 显示全部楼层 |阅读模式

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

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

x
目的:对50个数进行不重复随机排序
在百度上搜了关于随机数方面的代码,程序还是没法正常打印出所有随机不重复数字

  1. #include<stdio.h>
  2. #include<stdlib.h>
  3. #include<time.h>
  4. int main()
  5. {
  6. int i;
  7. srand((int)time(0));
  8. for(i=0;i<50;i++)
  9. {
  10. printf("%d\n",rand%36);
  11. }
  12. }

复制代码
最佳答案
2020-3-9 12:34:19
本帖最后由 jackz007 于 2020-3-9 12:38 编辑
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. #include <time.h>

  5. void random(int array[] , const int n)
  6. {
  7.     int c , k , m                          ;
  8.     bool f                                 ;
  9.     srand(time(0))                         ;
  10.     for(k = 0 ; k < n ; k ++) array[k] = 0 ;
  11.     m = 0                                  ;
  12.     while(m < n) {
  13.         c = rand() % n + 1                 ;
  14.         f = true                           ;
  15.         if (m) {
  16.             for(k = 0 ; k < m ; k ++) {
  17.                 if (array[k] == c) {
  18.                     f = false              ;
  19.                     break                  ;
  20.                 }
  21.             }
  22.         }
  23.         if (f) array[m ++] = c             ;
  24.     }
  25. }

  26. main(void)
  27. {
  28.     int array[50] , k , n = 50                           ;
  29.     random(array , n)                                    ;
  30.     printf("%2d" , array[0])                             ;
  31.     for(k = 1 ; k < n ; k ++) printf("\t%2d" , array[k]) ;
  32.     printf("\n")                                         ;
  33. }
复制代码

        编译运行实况:
  1. C:\Bin>g++ -o rand rand.c

  2. C:\Bin>rand
  3. 32      22      18      14      30      42      46      48      15      27
  4. 29       7      11      41       3      33      12      31      26      16
  5. 8      40      17       2      25      34      39       9      50      21
  6. 47       4       5      43      23      45      49       1      44      13
  7. 36      20      24      35      38       6      10      19      37      28

  8. C:\Bin>rand
  9. 49      34      37      27      35      47      41      29      38      36
  10. 3      32       4      40      24      13      39       8      20      50
  11. 18       5      11       1      12      44       7       9      10      30
  12. 26      43      33       6      19      16       2      15      31      22
  13. 17      23      25      14      48      45      21      42      28      46

  14. C:\Bin>rand
  15. 25      36      28      26      48      43      22      29       9      39
  16. 3       6      20      23      42      35      15      40      47      19
  17. 10      12       1      41      21       8      14      38      33      27
  18. 37       7      30      18      44      16      17      13       5      49
  19. 11       2       4      31      50      46      24      45      34      32

  20. C:\Bin>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

发表于 2020-3-9 12:34:19 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jackz007 于 2020-3-9 12:38 编辑
  1. #include <stdio.h>
  2. #include <stdlib.h>
  3. #include <string.h>

  4. #include <time.h>

  5. void random(int array[] , const int n)
  6. {
  7.     int c , k , m                          ;
  8.     bool f                                 ;
  9.     srand(time(0))                         ;
  10.     for(k = 0 ; k < n ; k ++) array[k] = 0 ;
  11.     m = 0                                  ;
  12.     while(m < n) {
  13.         c = rand() % n + 1                 ;
  14.         f = true                           ;
  15.         if (m) {
  16.             for(k = 0 ; k < m ; k ++) {
  17.                 if (array[k] == c) {
  18.                     f = false              ;
  19.                     break                  ;
  20.                 }
  21.             }
  22.         }
  23.         if (f) array[m ++] = c             ;
  24.     }
  25. }

  26. main(void)
  27. {
  28.     int array[50] , k , n = 50                           ;
  29.     random(array , n)                                    ;
  30.     printf("%2d" , array[0])                             ;
  31.     for(k = 1 ; k < n ; k ++) printf("\t%2d" , array[k]) ;
  32.     printf("\n")                                         ;
  33. }
复制代码

        编译运行实况:
  1. C:\Bin>g++ -o rand rand.c

  2. C:\Bin>rand
  3. 32      22      18      14      30      42      46      48      15      27
  4. 29       7      11      41       3      33      12      31      26      16
  5. 8      40      17       2      25      34      39       9      50      21
  6. 47       4       5      43      23      45      49       1      44      13
  7. 36      20      24      35      38       6      10      19      37      28

  8. C:\Bin>rand
  9. 49      34      37      27      35      47      41      29      38      36
  10. 3      32       4      40      24      13      39       8      20      50
  11. 18       5      11       1      12      44       7       9      10      30
  12. 26      43      33       6      19      16       2      15      31      22
  13. 17      23      25      14      48      45      21      42      28      46

  14. C:\Bin>rand
  15. 25      36      28      26      48      43      22      29       9      39
  16. 3       6      20      23      42      35      15      40      47      19
  17. 10      12       1      41      21       8      14      38      33      27
  18. 37       7      30      18      44      16      17      13       5      49
  19. 11       2       4      31      50      46      24      45      34      32

  20. C:\Bin>
复制代码
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-3-9 12:46:23 | 显示全部楼层
1、你的程序都没有对产生的随机数进行过滤当然会有重复的
2、你要打印50个随机数 而你定义的随机数范围就只有0-36 所以不管怎么取都会有重复的

先制定一个数组 保存产生的随机数 在每个随机数生成的时候就遍历这个数组 看有没有出现过 如果有 就重新生成随机数 如果没有再打印出来
小甲鱼最新课程 -> https://ilovefishc.com
回复 支持 反对

使用道具 举报

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

本版积分规则

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

GMT+8, 2025-7-2 05:08

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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