qiuqiuyaq 2022-02-22 08:31 采纳率: 97.9%
浏览 59

生成不重复的随机数保存在二维数组

怎么生成16个不重复的随机数保存在4行4列的二维数组中?求解谢谢

  • 写回答

2条回答 默认 最新

  • 赵4老师 2022-02-22 08:57
    关注

    随机必然有重复,所谓“不重复的随机”实际上是洗牌。洗牌算法参考下面:

    #include <stdio.h>
    #include <stdlib.h>
    #include <time.h>
    int d[6];
    int i,n,a,b,t;
    int c,j;
    void main() {
        srand(time(NULL));
        printf("shuffle 0..n-1 demo\n");
        for (n=1;n<=5;n++) {/* 测试1~5个元素 */
            printf("_____n=%d_____\n",n);
            j=1;
            for (c=1;c<=n;c++) j=j*c;/* j为n! */
            j*=n*2;
            for (c=1;c<=j;c++) {/* 测试n*2*n!次 */
                for (i=0;i<n;i++) d[i]=i;/* 填写0~n-1 */
                for (i=n;i>0;i--) {/* 打乱0~n-1 */
                    a=i-1;b=rand()%i;
                    if (a!=b) {t=d[a];d[a]=d[b];d[b]=t;}
                }
                printf("%04d:",c);
                for (i=0;i<n;i++) printf("%d",d[i]);
                printf("\n");
            }
        }
        printf("shuffle 1..n demo\n");
        for (n=1;n<=5;n++) {/* 测试1~5个元素 */
            printf("_____n=%d_____\n",n);
            j=1;
            for (c=1;c<=n;c++) j=j*c;/* j为n! */
            j*=n*2;
            for (c=1;c<=j;c++) {/* 测试n*2*n!次 */
                for (i=1;i<=n;i++) d[i]=i;/* 填写1~n */
                for (i=n;i>1;i--) {/* 打乱1~n */
                    a=i;b=rand()%i+1;
                    if (a!=b) {t=d[a];d[a]=d[b];d[b]=t;}
                }
                printf("%04d:",c);
                for (i=1;i<=n;i++) printf("%d",d[i]);
                printf("\n");
            }
        }
    }
    
    
    
    评论

报告相同问题?

问题事件

  • 修改了问题 2月22日
  • 创建了问题 2月22日