返回顶部
首页 > 资讯 > 后端开发 > 其他教程 >C语言中递归的实际应用与经典问题
  • 532
分享到

C语言中递归的实际应用与经典问题

2024-04-02 19:04:59 532人浏览 薄情痞子
摘要

目录一、什么是递归二、递归模板三、递归的实际应用1.阶乘递归2.斐波那契数列四、递归的经典问题汉诺塔问题青蛙跳台阶总结一、什么是递归 递归简单的来说就是在函数中调用自己 它通常把一

一、什么是递归

递归简单的来说就是在函数中调用自己

它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。

递归的两个必要条件:

存在限制条件,当满足这个限制条件的时候,递归便不再继续。

每次递归调用之后越来越接近这个限制条件。

二、递归模板


void recursion(参数0) 
{
    if (终止条件)
    {
        return;
    }
    else
    {
        recursion(参数1)
    }
}

三、递归的实际应用

1.阶乘递归


int tmp(int n)
{
	if (n == 1)
	{
		return 1;
	}
	else
	{
		return n*tmp(n - 1);
	}
}

2.斐波那契数列

斐波那契数列指的是这个数列从第3项开始,每一项都等于前两项之和。

递归算法


int fibonacci(int n)
{
	if (n<=2)
		return 1;
	else
	{
		return fibonacci(n - 1) + fibonacci(n - 2);
	}
}

非递归方法:


int fibonacci(int n)
{
	int a = 1;
	int b = 1;
	int c = 1;
	while (n > 2)
	{
		c = a + b;
		a = b;
		b = c;
		n--;
	}
	return c;
}

四、递归的经典问题

汉诺塔问题

汉诺塔问题来源:

汉诺塔(又称河内塔)问题是源于印度一个古老传说的益智玩具。大梵天创造世界的时候做了三根金刚石柱子,在一根柱子上从下往上按照大小顺序摞着64片黄金圆盘。大梵天命令婆罗门把圆盘从下面开始按大小顺序重新摆放在另一根柱子上。并且规定,在小圆盘上不能放大圆盘,在三根柱子之间一次只能移动一个圆盘。

这里我们使用的方法是从特殊到一般,这也是数学问题中常用的方法。

首先我们设计一个盘,那就直接把这个盘从自身柱子移到目标柱。

其次我们看两个盘,三根柱子两个盘,先将上面的柱子移动到中间柱,然后将最下面的柱子移动到目标柱,最后中间的柱子。

再来看多个盘


void hanno(int n, char a, char b, char c)
{
	if (n == 1)
	{
		printf("%c->%c\n", a, c);
	}
	else
	{
		hanno(n - 1, a, c, b);//递归处理,一开始的时候,先将n-1个盘子移至过渡柱z上后再将最底下的大盘子直接移至目标柱子y
		printf("%c->&c\n", a, c);
		hanno(n - 1, b, a, c);//然后重复以上步骤,递归处理放在过渡柱z上的n-1个盘子,
	}
}

青蛙跳台阶

一只青蛙可以一次跳 1 级台阶或一次跳 2 级台阶,例如:跳上第一级台阶只有一种跳法:直接跳 1 级即可。跳上两级台阶,有两种跳法: 每次跳 1 级,跳两次; 或者一次跳 2 级.问要跳上第 n 级台阶有多少种跳法?

解题思路

我们设台阶数位N;

当N=1时,当然只有1种跳法;

当N=2时,青蛙可以跳2次1层和跳1次2层;

当N=3时,当有3层台阶时,青蛙可以选择先跳1层,剩下2层台阶,所以此时就是有2层台阶时的跳法,有2种;当青蛙选择第一次跳2层台阶时,剩下1层台阶,此时有1层台阶时的跳法,所以3层台阶时的方法是:2层台阶的方法 + 1层台阶的方法。


#include<stdio.h>
int frog(int n)
{
   if(n == 1)
   {
      return 1;
   }
   if(n == 2)
   {
      return 2;
   }
   return frog(n-1) + frog(n-2);
}
int main()
{
   int n;
   scanf("%d",&n);
   int ways = frog(n);
   printf("%d\n",ways);
   return 0;
}

总结

到此这篇关于C语言中递归的实际应用与经典问题的文章就介绍到这了,更多相关C语言中递归应用内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: C语言中递归的实际应用与经典问题

本文链接: https://lsjlt.com/news/134227.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • C语言中递归的实际应用与经典问题
    目录一、什么是递归二、递归模板三、递归的实际应用1.阶乘递归2.斐波那契数列四、递归的经典问题汉诺塔问题青蛙跳台阶总结一、什么是递归 递归简单的来说就是在函数中调用自己 它通常把一...
    99+
    2024-04-02
  • C++ 函数的递归实现:递归的经典谜题示例?
    递归是一种编程技术,它允许函数调用自身以解决复杂问题,通过分解成子问题来实现。实战案例中,汉诺塔谜题的递归实现:1. 当只有一个圆盘时,直接移动到目标塔。2. 将小圆盘移动到辅助塔。3....
    99+
    2024-04-22
    c++ 递归
  • Go语言函数的递归调用与实际应用场景
    标题:Go语言函数的递归调用与实际应用场景 在Go语言中,函数的递归调用是一种强大的编程技巧,可以简洁地解决某些复杂的问题。递归调用指的是函数直接或间接地调用自身,通过将一个大问题拆分...
    99+
    2024-04-02
  • C语言递归在实践题目中应用详解
    目录递归知识点题目第一题第二题第三题第四题第五题第六题第七题递归知识点 递归概念:程序调用自身的编程技巧称为递归( recursion)。 递归做为一种算法在程序设计语言中广泛应用。...
    99+
    2024-04-02
  • C语言递归在实践题目中如何应用
    本篇内容主要讲解“C语言递归在实践题目中如何应用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“C语言递归在实践题目中如何应用”吧!递归知识点递归概念:程序调用自身的编程技巧称为递归( recur...
    99+
    2023-06-30
  • C++ 函数的递归实现:尾递归在实际应用中的示例?
    c++++中的尾递归优化:尾递归是一种函数在调用自身后立即返回的优化技术。通过指定noinline关键字,可在c++中实现尾递归,提高性能。实战案例:使用尾递归计算阶乘,该阶乘定义为从1...
    99+
    2024-04-22
    c++ 递归
  • 关于C语言中弱符号与弱引用的实际应用问题
    最近在学习《程序员的自我修养——链接、装载与库》时,get到了一个新的知识点:弱符号与弱引用。书中简短的介绍,让我了解到弱符号的含义以及使用方式。了解我的朋友,应该知道我喜欢将知识...
    99+
    2024-04-02
  • C++ 函数的递归实现:递归在语言分析中的应用示例?
    递归是一种函数在自身内部调用自身的编程范式。在 c++++ 中,可使用 operator() 运算符实现递归。递归在语言分析中可用作分析嵌套结构的工具,例如识别括号序列的合法性:如果序列...
    99+
    2024-04-22
    函数 c++ 递归
  • C语言递归应用实现扫雷游戏
    本文实例为大家分享了C语言递归应用实现扫雷游戏的具体代码,供大家参考,具体内容如下 游戏设计规则: 菜单  两个棋盘,Mine一个布置雷,Show一个给玩家看,玩...
    99+
    2024-04-02
  • C语言递归函数与汉诺塔问题怎么解决
    今天小编给大家分享一下C语言递归函数与汉诺塔问题怎么解决的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。递归函数直接或者间接调...
    99+
    2023-07-02
  • C语言递归函数与汉诺塔问题简明理解
    目录递归函数Hanio(汉诺塔)问题递归函数 直接或者间接调用函数本身。“自己调用自己” 什么情况下面可以使用递归呢 解决一个问题时,解决思路化成与问题本身类...
    99+
    2024-04-02
  • 怎么解疑C++对象传递实际应用问题
    这篇文章将为大家详细讲解有关怎么解疑C++对象传递实际应用问题,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。C++语言功能非常强大,不但能对各种程序设计提供支持,而且还具有面向对象的特征,极...
    99+
    2023-06-17
  • C语言中如何使用递归解决青蛙跳台阶问题
    这篇文章主要介绍C语言中如何使用递归解决青蛙跳台阶问题,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、求解思路台阶的数量为n。当 n = 1 时,青蛙有一种跳法,即跳1级台阶。当 n = 2 时,青蛙有两种跳法,即...
    99+
    2023-06-25
  • C语言实现经典扫雷小游戏完整代码(递归展开 + 选择标记)
    目录游戏介绍游戏整体框架游戏具体功能及实现1、雷盘的定义2、雷盘的初始化3、布置雷4、排查雷5、递归式展开一片6、获取周围雷的个数7、标记特定位置8、打印雷盘游戏完整代码 ...
    99+
    2024-04-02
  • Python递归文件中os模块的实际应用方式
    本篇内容主要讲解“Python递归文件中os模块的实际应用方式”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Python递归文件中os模块的实际应用方式”吧!os模块在实际的操作中应用非常广泛,...
    99+
    2023-06-17
  • C++ 函数的递归实现:递归在编程竞赛中的应用?
    递归是一种函数调用自身解决问题的技术,包含基线条件以终止递归。在 c++++ 中,可使用关键字 return 返回函数值并终止递归。递归可用于解决经典问题,如汉诺塔问题,其中它将 n 个...
    99+
    2024-04-22
    c++ 递归
  • C++ 函数的递归实现:如何使用递归来解决数学问题?
    递归是一种函数调用自身的编程技巧,用于解决复杂问题。在数学问题中,递归应用广泛,例如:计算阶乘:fac++torial(n) = n * factorial(n-1) if n >...
    99+
    2024-04-22
    c++ 递归 堆栈溢出
  • C语言运用函数的递归实现汉诺塔
    目录1、汉诺塔是如何实现的2、汉诺塔问题画图详解3、汉诺塔问题代码解释总结1、汉诺塔是如何实现的 下面是有三个盘子的示例: 从左到右一次是 A柱 B柱 C柱 A柱:起始位置 B柱:...
    99+
    2024-04-02
  • C语言中如何使用递归实现排雷游戏
    这篇文章主要介绍了C语言中如何使用递归实现排雷游戏,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。前言扫雷,相信各位都不陌生,以前每台电脑上面都会自带这个小游戏。因此,它可以说...
    99+
    2023-06-25
  • c语言中怎么用递归实现二分法查找
    递归实现二分法查找的思路如下: 首先定义一个函数,接收一个有序数组、待查找的元素、数组的起始位置和结束位置作为参数。 在函数中,首...
    99+
    2024-02-29
    c语言
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作