首页 > 编程知识 正文

汉罗塔编程,算法c语言实现

时间:2023-05-06 12:27:55 阅读:242733 作者:1170

axdxfC语言算法新手入门(3分钟学会) 前言

我相信大家在刚接触C语言时对axdxf递归算法有些头痛,现在依旧头痛的小朋友不要担心,你只要学完这篇文章,我相信你对axdxf算法十分感兴趣的。一看就会,不信试试?

具备知识

在看这篇文章之前,首先你得学会C语言函数知识点,仅此而已。

1.直接上代码 #include<stdio.h>int main(){ void move(int n,char a,char b,char c); //定义axdxf函数 int n; //板的个数 scanf("%d",&n); move(n,'a','b','c'); //调用函数 return 0; }void move(int n,char a,char b,char c){ if(n==1) printf("%c->%cn",a,c); //当只有一块需移动的板时,则直接从‘a'移动到'b' else { move(n-1,a,c,b); //n-1个板数从a移动到c,再从c移动到b printf("%c->%cn",a,c); move(n-1,b,a,c); //n-1个板数从b,借助a,移动到c }}

是不是看懂了呢?我知道就这么简**单,相信你现在一定解决了这道题目.

2.分析

从上面代码我们可以看出,我们在自定义函数内调用了自身,这就是递归函数的本质,xqdnht学会了递归函数的用法,你会发现,你写循环函数的次数会变少了,直接调用自身,显得代码整洁,易懂。或者,你是一名刚刚学C语言的朋友,为什么在定义函数时用 void不用int呢?这个呢,你不必太纠结,花个30秒去查看一下其它的博客,大致就会了解了.

3.小编恳求

这是我的第一篇博客,希望大家多多支持,不懂的可以评论区发言,还有,我写的不好的地方希望大家指正,在此,表达感谢,感谢大家看这篇博客。

版权声明:该文观点仅代表作者本人。处理文章:请发送邮件至 三1五14八八95#扣扣.com 举报,一经查实,本站将立刻删除。