| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 649 人关注过本帖
标题:一道数学题,找BUG
只看楼主 加入收藏
Daybreak0
Rank: 1
等 级:新手上路
帖 子:14
专家分:8
注 册:2010-4-7
收藏
 问题点数:0 回复次数:4 
一道数学题,找BUG
大家一起做游戏
幼儿园的小朋友们刚学习了如何数数,阿姨在下课时组织大家一起玩游戏。规则如下:所有的小朋友绕成一圈,顺序排号,从第一个小朋友开始报数,凡是报到固定数字(例如5)的,都退出该游戏,直到只剩下一位小朋友游戏才中止。

每个小朋友都希望自己能有更多的练习数数的机会,所以都希望成为最终被留下的那位。

现在,请大家帮小朋友们计算一下,在第一次排号的时候排到第几位才能成为最终被留下的小朋友。

输入:
        小朋友的个数(<=50)   要被练习的数字

输出:
        最终被留下的小朋友的序号

说明:
        如“要被练习的数字”是5,则每次数到5的同学要退出该游戏


大家帮我看看
我的程序有什么问题,交作业时,有一个隐藏测试用例总出错,无语了,

#include<stdio.h>
int main()
{
    int a,b,i,n,j=1,l=1,k=1,m[55]={0};
    scanf("%d%d",&a,&b);
    for(i=0;i<a+1;i++)
    {
        m[i]=i;
    }
    n=a;
    do
    {
        if(m[l])
        {
            if(j++>=b)
            {
                 m[l]=0;
                 j=1;
                 n--;
            }
            else
                 k=l;
            if(n<2) break;
        }
        if(l>=a)
            l=1;
        else
            l++;
    }while(1);
    printf("The left child is NO %d.\n",k);
}
搜索更多相关主题的帖子: 数学题 BUG 
2010-04-11 08:32
雨夜星光
Rank: 4
等 级:业余侠客
帖 子:66
专家分:230
注 册:2009-11-25
收藏
得分:0 
for(i=0;i<a+1;i++)
    {
        m[i]=i;
    }
改为
for(i=0;i<a;i++)
{
m[i]=i;
}
再试试?

C/C++交流群:65802335
2010-04-11 11:19
Daybreak0
Rank: 1
等 级:新手上路
帖 子:14
专家分:8
注 册:2010-4-7
收藏
得分:0 
那不就少一个数了吗?
2010-04-11 11:21
zglieren303
Rank: 1
等 级:新手上路
帖 子:29
专家分:1
注 册:2008-11-6
收藏
得分:0 
希望你写代码的时候变量尽量用有意义的单词,并且加适当的注释!提供以下代码,和你的思路是一样的。至于你的错误,自己去比较吧!代码比较浅显故略去注释!
#include<stdio.h>
#define MAX 51
int main()
{
 int child[MAX],leftChild,current,childNumber,exitNumber,count;
 printf("please input the childNumbers:");
 scanf("%d",&childNumber);
 printf("please input the exitNumber:");
 scanf("%d",&exitNumber);
 for(current=1;current<=childNumber;current++)
 child[current]=current;
 leftChild=childNumber;
 current=1;
 count=1;
 while(leftChild>1)
 {
  while(1)
  {
  while(count<exitNumber && current!=childNumber+1 ){count++;while(child[current]==0)current++;current++;while(child[current]==0)current++;}
  if(count==exitNumber)break;
  else
  current=1;
  }
  count=1;
  child[current++]=0;
  leftChild--;
  if (current==childNumber+1)
  current=1;
 }
  for(current=1;current<=childNumber;current++)
  if(child[current] !=0)
  printf("the left childNumber is:%d",current);
  return 0;
}
2010-04-11 12:59
Daybreak0
Rank: 1
等 级:新手上路
帖 子:14
专家分:8
注 册:2010-4-7
收藏
得分:0 
回复 4楼 zglieren303
谢谢你提的宝贵意见!
我会改的,还希望以后能多提些建议!,谢谢
2010-04-11 13:08
快速回复:一道数学题,找BUG
数据加载中...
 
   



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

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