博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
7-17 汉诺塔的非递归实现(25 分)(有待改进)
阅读量:6227 次
发布时间:2019-06-21

本文共 4103 字,大约阅读时间需要 13 分钟。

解题思路:1.

我们假设现在最小的圆盘在a柱子上,柱子为a,b,c

第一步:将最小圆盘移动到下一个柱子上,也就是b

第二步:对a柱子和c柱子进行顶上最小的元素进行判断,把小一点的那个圆盘移动到大一点的那个圆盘(有空则摞在空柱子上)。

重复上述两步就可以得到答案。

注意:这样得到的最后的答案不一定是摞在c上,如果N是偶数将摞在b上,所以如果N是偶数我们就令第二个柱子为c,第三个柱子为b,这样就一定最后是摞在c上的。

                      2.不过这个还是没通过最后一项大N的测试,提示输出超限

1 #include
2 #include
3 4 int main() 5 { 6 int i; 7 int n; 8 int topa = -1; 9 int topb = -1; 10 int topc = -1; 11 int temp; 12 int to = 1; //用to表示当前最小值所在的柱子,1为a,2为b 13 int count ; 14 scanf("%d",&n); 15 int a[n]; 16 int b[n]; 17 int c[n]; 18 19 count = 0; //如果n是偶数,那运行完成后C柱上有n个元素,奇数的话B柱上有n个元素 20 21 for( i=n; i>0; i--) 22 { 23 a[++topa] = i; //初始化低层数值大 24 25 } 26 while( 1 ) 27 { 28 if( n%2==0) 29 { 30 //这里主要处理n为偶数第一步放在b上 31 if( to==1) 32 { 33 //当前最小值在a上,往前移一步 34 temp = a[topa--]; 35 b[++topb] = temp; 36 to = 2; 37 printf("a -> b\n"); 38 if( a[topa]
c\n"); 44 count++; 45 if(count==n) 46 { 47 break; 48 } 49 } 50 else 51 { 52 //否则将c的最小值移动到a 53 temp = c[topc--]; 54 a[++topa] = temp; 55 printf("c -> a\n"); 56 count--; 57 } 58 59 } 60 else if( to==2) 61 { 62 temp = b[topb--]; 63 c[++topc] = temp; 64 to = 3; 65 printf("b -> c\n"); 66 count++; 67 if(count==n) 68 { 69 break; 70 } 71 if( a[topa]
b\n"); 76 } 77 else 78 { 79 temp = b[topb--]; 80 a[++topa] = temp; 81 printf("b -> a\n"); 82 } 83 84 } 85 else if( to==3) 86 { 87 temp = c[topc--]; 88 a[++topa] = temp; 89 to = 1; 90 printf("c -> a\n"); 91 count--; 92 if( b[topa]
c\n"); 97 count++; 98 if(count==n) 99 {100 break;101 }102 }103 else104 {105 temp = c[topc--];106 b[++topb] = temp;107 printf("c -> b\n");108 count--;109 }110 111 }112 }113 114 else115 {116 //这里主要处理n为奇数第一步放在c上117 if( to==1)118 {119 temp = a[topa--];120 b[++topb] = temp;121 to = 2;122 printf("a -> c\n");123 count++;124 if(count==n)125 {126 break;127 }128 if( a[topa]
b\n");133 134 }135 else136 {137 temp = c[topc--];138 a[++topa] = temp;139 printf("b -> a\n");140 }141 142 }143 else if( to==2)144 {145 temp = b[topb--];146 c[++topc] = temp;147 to = 3;148 printf("c -> b\n");149 count--;150 if( a[topa]
c\n");155 count++;156 if(count==n)157 {158 break;159 }160 }161 else162 {163 temp = b[topb--];164 a[++topa] = temp;165 printf("c -> a\n");166 count--;167 }168 169 }170 else if( to==3)171 {172 temp = c[topc--];173 a[++topa] = temp;174 to = 1;175 printf("b -> a\n");176 if( b[topa]
b\n");181 count--;182 }183 else184 {185 temp = c[topc--];186 b[++topb] = temp;187 printf("b -> c\n");188 count++;189 if(count==n)190 {191 break;192 }193 }194 195 }196 197 }198 }199 return 0;200 201 }

代码有点又臭又长,还没有完全通过测试盼路过的大神指导!!

转载于:https://www.cnblogs.com/yuxiaoba/p/8366141.html

你可能感兴趣的文章
link 与 controller
查看>>
实践:GNU构建系统
查看>>
扩展spring schema文件
查看>>
经典汉诺塔问题
查看>>
html5整理(一)
查看>>
spring-cloud-config的encrypt功能
查看>>
javascript引用类型之Date
查看>>
Fiddler调试(适合修复线上bug和直接调试线上问题)
查看>>
Vue+WebSocket+ES6+Canvas 制作【你画我猜】小游戏
查看>>
Java反射的封装
查看>>
精益 React 学习指南 (Lean React)- 1.1 React 介绍
查看>>
基于Flink的标准SQL操作支持
查看>>
用纯Javascript实现React Native的文件上传
查看>>
通信协议设计要点
查看>>
结构体中的 Lazy 属性探究
查看>>
iOS,Android网络抓包教程之tcpdump
查看>>
听飞狐聊JavaScript设计模式系列01
查看>>
CUBA Studio 8.2 发布,企业级应用开发平台
查看>>
玩转 React 服务器端渲染
查看>>
druid配置数据库连接使用密文密码
查看>>