注册 登录
编程论坛 新人交流区

经典猫吃鼠的c算法问题

aq100 发布于 2007-11-01 10:23, 805 次点击

要求如下:
有一只猫抓了n (n>1)个老鼠后向老鼠宣布:老鼠按自然数进行编号(1~n),并按自然数顺序排队,以后先后次序不准变;于是猫每天吃掉编号为奇数的老鼠,剩下的老鼠再按原次序进行自然数编号,直至某一天只剩下一只小老鼠;而该小老鼠是猫从第一天起就想吃掉的那只,请问这只小老鼠的最初编号是几?
我的程序如下:
#include <iostream.h>
#include <assert.h>

struct mouse              //链“节点”类声明
{
int n;
mouse *nextptr;
};

int cat_mouse(int num)         //函数定义
{
mouse *headptr=0,*tailptr=0,*frontptr,*p;
int i;

//先把1个老鼠加入链作为链首节点
headptr=tailptr=new mouse;
assert(headptr!=NULL);      //动态内存分配异常处理
headptr->n=1;          //老鼠的编号
headptr->nextptr=NULL;

//在链尾再添加n-1个老鼠
for(i=2;i<=num;++i)
{p=new mouse;
assert(p!=NULL);
p->n=i;
cout<<p->n<<" ";
tailptr->nextptr=p;
tailptr=p;
}
tailptr->nextptr=NULL;    //设置链尾节点的“下一节点地址”为空

//开始删除老鼠
while(headptr!=tailptr) //每循环一次,删除链上的奇节点,直至只剩下1个节点
{ p=headptr->nextptr;      //链的首节点总是先被删除
delete headptr;        //析构首节点
headptr=frontptr=p;      //本次循环的第2个节点成为链的首节点
i=2;             //从第2个节点开始循环:删除链的奇节点
while(p!=NULL)        //从2开始循环至链尾节点
{if((i%2)==1)          //是奇节点
{if (p->nextptr==NULL)    //如果该奇节点是最后一个节点
{frontptr->nextptr=NULL;    //前一节点成为链的尾节点
tailptr=frontptr;
delete p;
p=NULL;        //因本循环的判断条件是p!=NULL,到链尾,所以置为0
}
else           //是奇节点但不是尾节点,删除
{frontptr->nextptr=p->nextptr;   //从链上删除该奇节点
delete p;
p=frontptr->nextptr;    //下一节点的地址已保存在frontPtr的nextPtr中
++i;
}
}
else
{frontptr=p;
p=p->nextptr;
++i;
}
}
}
return headptr->n;     //返回最后一个节点的编号
}

void main()        //主函数
{
int i, num;
do{cout<<"\n请输入老鼠的只数(大于1,输入0退出):";
cin>>num;
if(num>1)
{i=cat_mouse(num);
cout<<"最后剩下的一只老鼠是:"<<i<<endl;
}
}while(num!=0);
}

如果猫每天吃掉编号为偶数的老鼠 那老鼠的最初编号是几?如何改程序,我是新手请大家指点下,谢谢了!!

18 回复
#2
liuxianen2007-11-01 11:28
先化成数学问题,在编程,就不会有任何疑问拉
#3
a33149692007-11-01 14:31
#4
韶华2007-11-02 00:47
#5
googleaw2007-11-02 02:07

经典算法

#6
lctt2007-11-02 09:06
看不懂
#7
liuzhuyu2007-11-02 09:29
回复:(aq100)经典猫吃鼠的c算法问题

不明白什么意思

#8
daihaoshasho2007-11-02 14:34
哦 ??
我学的很次 看不明白啊 !@!!! 1
#9
visolleon2007-11-02 15:40

没看你程序! 不过我知道这个答案是多少!

假设猫吃了m天,用程序也就是循环了m次,才得到最后一只老鼠,
那么,最后那只没有被吃的老鼠应该是开始的编号应该是:2的m次方

所以你利用循环,找出循环次数,也就得到了那只老鼠的编号...

#10
ruanguohan2007-11-04 22:02
#11
小鸟向前飞2007-11-04 22:24
#12
木子猪猪2007-11-04 22:36
我的水平还没有到这么长的程序呢
#13
zmh88111zmh2007-11-04 23:46
看不懂
#14
幸福天堂2007-11-05 00:23
哇,很好!
#15
skykingycl2007-11-05 09:15
这个程序有错的  根本运行不起呢. 我现在正需要这样的程序呢  麻烦高手帮忙修改下,谢谢啦.
#16
skykingycl2007-11-05 09:19
偶就用这个,哪个大大帮忙把程序给我修改下啦 我就制作这个报告呢 .
#17
it的脚本小孩2007-11-05 13:24
headptr=frontptr=p; 这句话好像不合法阿
#18
hugang622007-11-05 14:47
#19
LOvE老鼠YoU2007-11-05 14:54

一个鸟字都看不懂, 果然学编程真的很难
1