| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 932 人关注过本帖
标题:智力捕鼠大神求指教
只看楼主 加入收藏
n172474108
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2016-8-28
结帖率:0
收藏
已结贴  问题点数:20 回复次数:5 
智力捕鼠大神求指教
#include <stdio.h>
#include<stdlib.h>
int main()
{
    int i = 0, t = 0, p = 1, a[21];
    for (i = 0; i<21; i++) a[i] = 0;
                                    
    for (i = 0; i<21; i++, i %= 21)
    {
        t += a[i] == 0;//
        if (t == p)
        {
            a[i] = p; t = 0; p++;
            if (p>21)
                break;
        }

    }
    for (i = 0; i<21; i++)
    {

        printf("%5d", a[i]);
        if ((i + 1) % 7 == 0)
            printf("\n");
    }
    system("pause");
这道题的思路是什么,怎么理解?
搜索更多相关主题的帖子: include 捕鼠 
2016-12-09 18:27
n172474108
Rank: 1
等 级:新手上路
帖 子:17
专家分:0
注 册:2016-8-28
收藏
得分:0 

智力捕鼠。将21只老鼠(编号分别为1~21)以任意顺序排成一圈。取某个位置坐起点,从1开始往下数,
当数到的老鼠的数正好和老鼠的编号相同时,表示这只老鼠被抓住。然后再从1开始往下数,
被抓住的老鼠编号下次碰到时不再数它,如果数到的数超过没有抓住过的老鼠的最大编号
(开始时最大编号21)就算失败,这就要求老鼠以一定的顺序排列,以便从指定位置开始数数时
进行21就将老鼠全部抓住。设开始数数的位置为1。应将老鼠进行怎样排位才能捕抓成功。
2016-12-09 18:28
yangfrancis
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:贵宾
威 望:141
帖 子:1510
专家分:7661
注 册:2014-5-19
收藏
得分:10 
不知道能成功的排列方式能占到几成,如果机率不太小的话可以采用随机排序,再测试能否成功,如果失败,用循环语句让它重新排一种方式。如果机率小就不适合这样做了。
2016-12-09 21:49
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:10 
如果只剩下最后一只老鼠,则一定会被抓,如果只剩下两只老鼠,则前面的老鼠编号%2为1或者后面老鼠编号%2为0,如果还剩3只老鼠,第一只老鼠编号%3能为1或者第二只老鼠编号%2为2,或者第三只老鼠编号%3为0这样再递归到剩下数为2的情况(这个代表思考一下,可以忽略)。

思考了一下,编号1放在第一位,编号2放在第三位,编号3放在第六位,编号4放在第十位,编保证编号放位走过的位置等于n
放位大于21可以按约瑟夫环问题处理~这样试试看。

解读完毕,发现该问题是约瑟夫环的变种,约瑟夫环问题一般开除的是常量,而本问题开除的是和编号n有关的变量。

(刚才解读题意有误,已更正)

[此贴子已经被作者于2016-12-9 23:04编辑过]


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-12-09 22:33
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 4楼 九转星河
对上楼补充一下,如果保证被捕编号都是前面走过的最小值,就不会出现因为走过编号过少和“巧合”编号等于走过次数相等意外被捕而导致失控的情况。

当然,上楼只是给出了之一解,却没有验证是否是唯一解~

[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-12-09 22:42
九转星河
Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19Rank: 19
来 自:长长久久
等 级:贵宾
威 望:52
帖 子:5023
专家分:14003
注 册:2016-10-22
收藏
得分:0 
回复 4楼 九转星河
图片附件: 游客没有浏览图片的权限,请 登录注册


拿着图片对比一下,原来是从“1”是指被捕编号之后开始数的,4楼说法要更正,不过原理是一样的。贴上图理解就简单了


现已更正

[此贴子已经被作者于2016-12-9 23:04编辑过]


[code]/*~个性签名:bug是什么意思?bug是看上去没有可能的东西实际上是有可能做到的 就是这样~2018-08-08更~*/[/code]
2016-12-09 23:00
快速回复:智力捕鼠大神求指教
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.044156 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved