有bug的随机生成不重复1-9的代码
Posted yfish
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了有bug的随机生成不重复1-9的代码相关的知识,希望对你有一定的参考价值。
#include "pch.h" #include "stdio.h" #include "stdlib.h" #include "time.h" int m[9] = {0}; int main(void) { srand(time(0)); for (int i = 1; i < 10; i++) { m[i - 1] = rand()%9+1; for (int j = 0; j < i - 1; j++) { while (m[j] == m[i - 1]) { m[i - 1] = rand() % 9 + 1; } } } for (int i = 0; i < 9; i++) { printf("%d ",m[i]); } }
大体思路是没有问题的,产生一个随机数,我们假设它在 m[i-1] 位置上,那么需要从m[0]到m[i-2]和m[i-1]依次判断随机数有没有在之前产生过。
while (m[j] == m[i - 1]) { m[i - 1] = rand() % 9 + 1; }
但这段是有问题的,当遇到前面已经产生过的随机数则又产生一个新的随机数,而此时m[j]的j的值可能不是从0开始的,所以m[j]会从当前j的值一直走到m[i-2],而少了m[0]~m[j-1]的判断,这是产生bug的根本原因。
以上是关于有bug的随机生成不重复1-9的代码的主要内容,如果未能解决你的问题,请参考以下文章