| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 799 人关注过本帖
标题:经典猫吃鼠的c算法问题
只看楼主 加入收藏
aq100
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2007-11-1
收藏
 问题点数:0 回复次数:18 
经典猫吃鼠的c算法问题

要求如下:
有一只猫抓了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);
}

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

搜索更多相关主题的帖子: 算法 经典 
2007-11-01 10:23
liuxianen
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2007-11-1
收藏
得分:0 
先化成数学问题,在编程,就不会有任何疑问拉
2007-11-01 11:28
a3314969
Rank: 1
等 级:新手上路
帖 子:13
专家分:0
注 册:2007-10-16
收藏
得分:0 

2007-11-01 14:31
韶华
Rank: 1
等 级:新手上路
帖 子:5
专家分:0
注 册:2007-11-1
收藏
得分:0 
2007-11-02 00:47
googleaw
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2007-11-2
收藏
得分:0 

经典算法

2007-11-02 02:07
lctt
Rank: 1
等 级:新手上路
帖 子:24
专家分:0
注 册:2007-10-16
收藏
得分:0 
看不懂
2007-11-02 09:06
liuzhuyu
Rank: 1
等 级:新手上路
帖 子:14
专家分:0
注 册:2007-10-31
收藏
得分:0 
回复:(aq100)经典猫吃鼠的c算法问题

不明白什么意思

2007-11-02 09:29
daihaoshasho
Rank: 1
等 级:新手上路
帖 子:11
专家分:0
注 册:2007-11-2
收藏
得分:0 
哦 ??
我学的很次 看不明白啊 !@!!! 1
2007-11-02 14:34
visolleon
Rank: 3Rank: 3
等 级:论坛游侠
威 望:1
帖 子:71
专家分:182
注 册:2007-1-16
收藏
得分:0 

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

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

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


2007-11-02 15:40
ruanguohan
Rank: 2
等 级:论坛游民
帖 子:67
专家分:21
注 册:2007-10-28
收藏
得分:0 

淘宝小店:http://shop62973352.
2007-11-04 22:02
快速回复:经典猫吃鼠的c算法问题
数据加载中...
 
   



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

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