免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 1882 | 回复: 3
打印 上一主题 下一主题

[算法] 汉诺塔,非递归。 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-12-12 14:00 |只看该作者 |倒序浏览
#include <stdio.h>
#include <stdlib.h>

typedef struct _HANNO
{
&nbsp;&nbsp;&nbsp;&nbsp;int n;
&nbsp;&nbsp;&nbsp;&nbsp;int from;
&nbsp;&nbsp;&nbsp;&nbsp;int to;
&nbsp;&nbsp;&nbsp;&nbsp;int temp;
} HANNO;

void hanno_run(int n, int from, int temp, int to);

int main(void)
{
&nbsp;&nbsp;&nbsp;&nbsp;hanno_run(3, 1, 2, 3);
&nbsp;&nbsp;&nbsp;&nbsp;return 0;
}

void hanno_run(int n, int from, int temp, int to)
{
&nbsp;&nbsp;&nbsp;&nbsp;int max = n * 2 - 1;
&nbsp;&nbsp;&nbsp;&nbsp;HANNO *hanno = (HANNO *)malloc(max * sizeof(HANNO));
&nbsp;&nbsp;&nbsp;&nbsp;HANNO *p = hanno;
&nbsp;&nbsp;&nbsp;&nbsp;int count = 0;

&nbsp;&nbsp;&nbsp;&nbsp;p->n = n;
&nbsp;&nbsp;&nbsp;&nbsp;p->from = from;
&nbsp;&nbsp;&nbsp;&nbsp;p->to = to;
&nbsp;&nbsp;&nbsp;&nbsp;p->temp = temp;
&nbsp;&nbsp;&nbsp;&nbsp;p++;

&nbsp;&nbsp;&nbsp;&nbsp;while (p > hanno)
&nbsp;&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p--;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;from = p->from;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;to = p->to;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;n = p->n;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;temp = p->temp;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;if (1 == n)
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;{
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;count ++;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;printf("%d -> %d\n", p->from, p->to);
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;continue;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->n = n - 1;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->from = temp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->to = to;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->temp = from;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p++;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->n = 1;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->from = from;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->to = to;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->temp = temp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p++;

&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->n = n - 1;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->from = from;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->to = temp;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p->temp = to;
&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;&nbsp;p++;
&nbsp;&nbsp;&nbsp;&nbsp;}

&nbsp;&nbsp;&nbsp;&nbsp;free(hanno);

&nbsp;&nbsp;&nbsp;&nbsp;printf("total %d steps.\n", count);
}

论坛徽章:
0
2 [报告]
发表于 2007-12-12 14:43 |只看该作者
有意思

论坛徽章:
0
3 [报告]
发表于 2007-12-12 14:57 |只看该作者

回复 #1 yuanchengjun 的帖子

C 风格的 C++

论坛徽章:
0
4 [报告]
发表于 2007-12-12 15:35 |只看该作者
本来就是C, 哪来的C++?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP