汉罗塔

汉罗塔/*汉罗塔问题: 规则:1.每次只能移动一个圆盘   2。圆盘可以插在X,Y和Z中的任一塔座上   3.任何时候都不能将一个较大的圆盘压在较小的圆盘之上。*/#includeintcount=0;voidmove(charx,intn,charz){ ++count; printf(“%d   %c—>%c\n”,n,x,z);}

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

/*汉罗塔问题:
 规则:1.每次只能移动一个圆盘
    2。圆盘可以插在X,Y和Z中的任一塔座上
    3.任何时候都不能将一个较大的圆盘压在较小的圆盘之上。
*/

#include <stdio.h>
int count=0;
void move(char x,int n,char z)
{

 ++count;
 printf(“%d    %c—>%c\n”,n,x,z);
}

/*  将塔座x上按直径由小到大且自上而下编号为1–n的n个圆盘按规则搬到塔座Z上,Y可用作辅助塔。
 搬动操作move(x,y,z)*/
void hanoi(int n ,char x, char y, char z)
{

 if(1==n)
  move(x,1,z);  //将编号为1的圆盘从x移到Z上
 else
 {

  hanoi(n-1,x,z,y); //将编号为1到n-1的圆盘移到Y上,可以借助Z
  move(x,n,z);  //将编号为n的圆盘从x移动到Z上
  hanoi(n-1,y,x,z); //将y上编号为1到n的圆盘移到z,x作为辅助塔
 }

}
int main()
{

 int n;
 printf(“Please enter the number of disk: “);
 scanf(“%d\n”,&n);
 hanoi(n,’A’,’B’,’C’);
 printf(“Total need move number:  %d\n”,count);
 return 0;
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/182639.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • lunix针对用户的常用操作命令

    lunix针对用户的常用操作命令(1)使用who查看目前有哪些用户登录了服务器,见下图[root@vm18~]#whorootpts/02015-03-2710:23(192.168.9.188)从上文可以看出用户root使用ip地址为192.168.9.188登录到linux系统上 (2)看看root都在什么时间登录过系统 [root@vm18~]#lastrootrootpts/0192.168.9.1…

    2022年10月3日
    0
  • yolov5训练命令_yolo在coco上训练

    yolov5训练命令_yolo在coco上训练@本人环境声明:系统环境:Ubuntu18.04.1cuda版本:10.2.89cudnn版本:7.6.5torch版本:1.5.0torchvision版本:0.6.0项目代码yolov5,官网,项目开源的时间:20200601自定义数据集:#1安装环境依赖##1.1克隆项目gitclonehttps://github.com/ultralytics/yolov5#clonerepo如果下载比较慢,建议使用下面的镜像下载:gitclonehttps:

    2022年9月24日
    0
  • 队列的基本操作(顺序队列、循环队列、链式队列)

    队列的基本操作(顺序队列、循环队列、链式队列)&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;队列也是一种线性表,是一种先进先出的线性结构。队列只允许在表的一端进行插入(入队)、删除(出队)操作。允许插入的一端称为队尾,允许删除的一端称为队头。&amp;nbsp;&amp;nbsp;&amp;nbsp;&amp;nbsp;队列的基本操作包括:初始化队列:InitQueue(Q)&amp;nbsp;&

    2022年5月9日
    43
  • 最新面试题汇总(附带答案)【建议看看】

    最新面试题汇总(附带答案)【建议看看】1.性能测试关注的指标是什么?从外部看,性能测试主要关注如下三个指标:吞吐量:每秒钟系统能够处理的请求数、任务数响应时间:服务处理一个请求或一个任务的耗时错误率:一批请求中结果出错的请求所占比例从服务器的角度看,性能测试主要关注CPU、内存、服务器负载、网络、磁盘IO等。2.性能测试怎么做的?/如果你要进行性能测试,你是如何展开操作的?1.确定关键业务,关键路径;2.确定测试的关键数据。比如并发量,响应时间,循环次数等;3.准备测试环境,完成脚本录制或脚本开发;4.执行测试,观察或监控

    2022年9月27日
    0
  • 使用WinSCP连接虚拟机主机,提示“网络错误拒绝连接”

    使用WinSCP连接虚拟机主机,提示“网络错误拒绝连接”工作遇到的

    2022年9月16日
    0
  • 一致性哈希算法的问题

    一致性哈希算法的问题本文将从如下三个方面探探一致性哈希算法一致性哈希算法经典实用场景 一致性哈希算法通常不适合用于服务类负载均衡 面试应对之策1、一致性哈希算法经典使用场景在数据库存储领域如果单表数据量很大,通常会采用分库分表,同样在缓存领域同样需要分库,下面以一个非常常见的Redis分库架构为例进行阐述。将上述3个Redis节点称之为分片,每一个节点存储部分数据,期间需要使用负载均衡算法,将数据尽量分摊到各个节点,充分发挥分布式的优势,提升系统缓存访问的性能。在分布缓存领域,对数据存在新增与..

    2022年7月27日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号