鱼C论坛

 找回密码
 立即注册
查看: 2852|回复: 5

[已解决]c语言洗牌问题,求大佬解答

[复制链接]
发表于 2021-9-7 10:51:35 | 显示全部楼层 |阅读模式
20鱼币
void shuffle(int array[], int length)
{
        int index, temp, i;

        srand(time(NULL));
        for (i = 0; i < length; i++)
        {
                index = rand() % (length - i) + i;
                if (index != i)
                {
                        temp = array[i];
                        array[i] = array[index];
                        array[index] = temp;
                }
        }
}
大佬们好,
这是个c语言洗牌的函数,我想问下就是  index = rand() % (length - i) + i;这句话讲index的范围限制在i到length-i-
1之间,这样的设定是为什么呀?
最开始是0-54,然后1-53,然后是2-52,不断缩小这是为什么呀?
最佳答案
2021-9-7 10:51:36
本帖最后由 jhq999 于 2021-9-7 12:11 编辑

这是个c语言洗牌的函数,我想问下就是  index = rand() % (length - i) + i;这句话讲index的范围限制在i到length-i-
1之间,这样的设定是为什么呀?

位置i和i到length-1之间的随机取的的值交换,
length=54;
length - i是54-》53-》52,别忘了后面还有加i。 index的取值范围一直是i到length-1之间。直到i=53,取余为0,所以index=53,不交换
至于i前面都是随机完了的,大多数都已经随机交换了,就相当于已经洗完牌了

最佳答案

查看完整内容

这是个c语言洗牌的函数,我想问下就是 index = rand() % (length - i) + i;这句话讲index的范围限制在i到length-i- 1之间,这样的设定是为什么呀? 位置i和i到length-1之间的随机取的的值交换, length=54; length - i是54-》53-》52,别忘了后面还有加i。 index的取值范围一直是i到length-1之间。直到i=53,取余为0,所以index=53,不交换 至于i前面都是随机完了的,大多数都已经随机交换了,就相当于已经洗完牌了
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-9-7 10:51:36 | 显示全部楼层    本楼为最佳答案   
本帖最后由 jhq999 于 2021-9-7 12:11 编辑

这是个c语言洗牌的函数,我想问下就是  index = rand() % (length - i) + i;这句话讲index的范围限制在i到length-i-
1之间,这样的设定是为什么呀?

位置i和i到length-1之间的随机取的的值交换,
length=54;
length - i是54-》53-》52,别忘了后面还有加i。 index的取值范围一直是i到length-1之间。直到i=53,取余为0,所以index=53,不交换
至于i前面都是随机完了的,大多数都已经随机交换了,就相当于已经洗完牌了

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
wyz20010429 + 5 + 5 + 3 鱼C有你更精彩^_^

查看全部评分

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-9-7 19:08:03 | 显示全部楼层
jhq999 发表于 2021-9-7 10:51
这是个c语言洗牌的函数,我想问下就是  index = rand() % (length - i) + i;这句话讲index的范围限制在i到l ...

那大佬他为什么不直接index = rand() % length 这样写呢?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-9-7 19:08:37 | 显示全部楼层
jhq999 发表于 2021-9-7 10:51
这是个c语言洗牌的函数,我想问下就是  index = rand() % (length - i) + i;这句话讲index的范围限制在i到l ...

他这样写又什么好处呀?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2021-9-7 19:39:19 | 显示全部楼层
wyz20010429 发表于 2021-9-7 19:08
那大佬他为什么不直接index = rand() % length 这样写呢?

index = rand() % length;在整个里面随机,有可能本来已经调换过的又调换回来了。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2021-9-8 06:50:03 | 显示全部楼层
jhq999 发表于 2021-9-7 19:39
index = rand() % length;在整个里面随机,有可能本来已经调换过的又调换回来了。

好的,感谢大佬
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

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

GMT+8, 2024-11-17 22:23

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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