C# 递归算法详解

作者:智者见智 时间:2021-09-10 19:08:44 

1)1、1、2、3、5、8.......用递归算法求第30位数的值?

首先我们能够发现从第3位数起后一位数等于前两位数值之和,即:x=(x-1)+(x-2),x>2;

这里须要不断的相加,第一时刻就会想到循环处理,我们尝试用数组去装载这些数值,即:


int[] a=new int[30];
a[0]=1;
a[1]=1;
for(int i=2;i<30;i++)
{
   a[i]=a[i-1]+a[i-2];
}

求a[29]的值即为第30位数的值,递归该怎样处理呢?相同定义函数


fun(n)
{
   return fun(n-1)+fun(n-2)//n为第几位数,第n位数返回值等于第n-1位数的值与第n-2位数的值之和
}

仅仅有当n>2为这样的情况,就能够做个推断


fun(n)
{
    if(n==1 || n==2)
         return 1;
    else
         return fun(n-1)+fun(n-2);
}

求fun(30);

2)编写计算斐波那契(Fibonacci)数列的第n项函数fib(n)斐波那契数列为:0、1、1、2、3、……,

即:

fib(0)=0;

fib(1)=1;

fib(n)=fib(n-1)+fib(n-2) (当n>1时)

写成递归函数有:


int fib(int n)
{
if (n==0) return 0;
if (n==1) return 1;
if (n>1) return fib(n-1)+fib(n-2);
}

递归算法的运行过程分递推和回归两个阶段。在递推阶段,把较复杂的问题(规模为n)的求解推到比原问题简单一些的问题(规模小于n)的求解。

比如上例中,求解fib(n),把它推到求解fib(n-1)和fib(n-2)。也就是说,为计算fib(n),必须先计算fib(n-1)和fib(n-2),而计算fib(n-1)和fib(n-2),又必须先计算fib(n-3)和fib(n-4)。依次类推,直至计算fib(1)和fib(0),分别能马上得到结果1和0。在递推阶段,必需要有终止递归的

情况。比如在函数fib中,当n为1和0的情况。

在回归阶段,当获得最简单情况的解后,逐级返回,依次得到稍复杂问题的解,比如得到fib(1)和fib(0)后,返回得到fib(2)的结果,……,在得到了fib(n-1)和fib(n-2)的结果后,返回得到fib(n)的结果。

在编写递归函数时要注意,函数中的局部变量和參数知识局限于当前调用层,当递推进入“简单问题”层时,原来层次上的參数和局部变量便被隐蔽起来。在一系列“简单问题”层,它们各有自己的參数和局部变量。

因为递归引起一系列的函数调用,而且可能会有一系列的反复计算,递归算法的运行效率相对较低。当某个递归算法能较方便地转换成递推算法时,通常按递推算法编敲代码。比如上例计算斐波那契数列的第n项的函数fib(n)应採用递推算法,即从斐波那契数列的前两项出发,逐次由前两项计算出下一项,直至计算出要求的第n项。

3)求1+2+3+4+5+....+n的值


Fun(n)=n+Fun(n-1)
n=1时为1
Fun(n)
{
    if(n==1)
      return 1;
    else
     return n+Fun(n-1);
}

4)有两个整数型数组,从小到大排列,编写一个算法将其合并到一个数组中,并从小到大排列


public void Fun()
   {
       int[] a = { 1, 3, 5, 7, 9, 10 };
       int[] b = { 2, 4, 6, 8, 11, 12, 15 };
       int[] c = new int[a.Length + b.Length];
       ArrayList al=new ArrayList();
       int i=0;
       int j=0;
       while (i <= a.Length - 1 && j <= b.Length - 1)
       {  //循环比較把小的放到前面
           if (a[i] < b[j])
           {
               al.Add(a[i++]);
           }
           else
           {
               al.Add(b[j++]);
           }
       }
       //两个数组的长度不一样,必有个数组没比較完
       while (i <= a.Length - 1)//加入a中剩下的
       {
           al.Add(a[i++]);
       }
       while (j <= b.Length - 1)//加入b中剩下的
       {
           al.Add(b[j++]);
       }
       for (int ii = 0; ii <= c.Length-1 ; ii++)
       {
           c[ii] = (int)al[ii];
       }
   }

来源:https://www.cnblogs.com/zhaoyl9/p/10304620.html

标签:C#,递归,算法
0
投稿

猜你喜欢

  • Java多线程-线程的同步与锁的问题

    2023-11-29 01:40:12
  • java.sql.Date和java.util.Date的区别详解

    2023-11-28 16:15:09
  • Java 批量文件压缩导出并下载到本地示例代码

    2023-04-15 07:29:30
  • JavaWeb开发基于ssm的校园服务系统(实例详解)

    2022-11-07 16:40:48
  • spring boot 注入 property的三种方式(推荐)

    2023-01-23 05:10:27
  • 详细解读C++编程中的匿名类类型和位域

    2023-11-02 23:08:18
  • 深入理解spring事务

    2023-10-13 14:51:36
  • Java基于分治算法实现的棋盘覆盖问题示例

    2021-07-17 14:05:16
  • Android 使用gradle打包Assets目录的案例

    2023-08-05 22:29:45
  • Springboot 使用内置tomcat禁止不安全HTTP的方法

    2022-07-12 10:45:45
  • Spring集成MyBatis 及Aop分页的实现代码

    2022-01-06 14:30:47
  • springboot openfeign从JSON文件读取数据问题

    2023-11-09 15:55:55
  • 在Java中String和Date、Timestamp之间的转换

    2023-10-07 13:52:36
  • java.lang.Runtime.exec的左膀右臂:流输入和流读取详解

    2023-08-06 04:59:03
  • java synchronized 锁机制原理详解

    2021-10-15 05:29:47
  • java图形界面编程之模拟血压计

    2023-10-01 07:16:05
  • Java的Swing编程中使用SwingWorker线程模式及顶层容器

    2021-09-09 08:45:06
  • SpringBoot 配置文件总结

    2021-09-06 13:12:57
  • unity scrollRect实现按页码翻页效果

    2021-10-11 11:52:43
  • 详解关于SpringBoot的外部化配置使用记录

    2023-08-10 03:54:54
  • asp之家 软件编程 m.aspxhome.com