c# 递归算法
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);
网站看到别人的分析也不错:
【问题】 编写计算斐波那契(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项。
其他递归解题:
求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);
}
有两个整数型数组,从小到大排列,编写一个算法将其合并到一个数组中,并从小到大排列
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];
}
}
首先碰到的是这样的一首题目:计算数组{1,1,2,3,5,8.......} 第30位值,不用递归,我写出了以下这样的代码:






















写出来,十分的累赘,于是改为归递算法来写,一目了然,十分明了。以下是代码:


















做了一些练习:
1. 计算1+2+3+4+...+100的值












2. 计算1 -2 +3 +-4+ 5- 6 + 7 - 8 + 9的值














3.汉诺塔问题






















4.用递归法将一个整数n转换成字符串,例如,输入483,就输出字符串"483".n的位数不确定,可以是任意位数的整数。
















- package com.dylan.algorithm;
- import javax.sound.sampled.Mixer;
- public class BinarySearch {
- public static void main(String[] args) {
- // TODO Auto-generated method stub
- int arr[] ={10,24,36,47,68,89,130};
- int index = Search(arr, 89);
- System.out.println(index);
- }
- /*实现二分查找算法(折半算法)
- *要确定数组是排序好的
- *最好是里面一定包含该元素
- */
- public static int Search(int[] arr,int key ) {
- int min =0;
- int max=arr.length-1;
- int mid = (min+max)/2;
- while(arr[mid]!=key){
- if (arr[mid]<key) {
- min=mid+1;
- }else if (arr[mid]>key) {
- max=mid-1;
- }
- if(max<min){
- return -1;//里面不存在值为key的元素
- }
- //继续折半
- mid=(min+max)/2;
- }
- return mid;
- }
- }
c# 递归算法的更多相关文章
- 递归算法经典实例小结(C#实现)
一 .递归算法简介 在数学与计算机科学中,递归是指在函数的定义中使用函数自身的方法. 递归算法是一种直接或者间接地调用自身算法的过程.在计算机编写程序中,递归算法对解决一大类问题是十分有效的,它往往 ...
- 转: JAVA递归算法实例小结
一.递归算法设计的基本思想是: 对于一个复杂的问题,把原问题分解为若干个相对简单类同的子问题,继续下去直到子问题简单到能够直接求解,也就是说到了递推的出口,这样原问题就有递推得解. 在做递归算法的时候 ...
- xml 读取递归算法
xml 读取递归算法:
- 后台返回字符串类型function的处理 (递归算法)
$(function(){ $.ajax({ type: "post", url: "${ctx}/modules/fos/reference/echart", ...
- JAVA递归算法
1.什么是递归算法 递归算法就是直接或间接调用自己的算法 2.问题1:一列数的规则如下: 1.1.2.3.5.8.13.21.34 ,求第30位数是多少?使用递归实现 public class Fib ...
- 【Tree 1】树形结构数据呈现的递归算法实现
一.基本概况 在我的项目中,常常会用到树形结构的数据,最为明显的就是左边菜单栏,类似于window folder一样的东西. 而我之前一直是借助前端封装好的ZTree等工具实现展示,而后台则通常使用递 ...
- N个数全排列的非递归算法
//N个数全排列的非递归算法 #include"stdio.h" void swap(int &a, int &b) { int temp; temp = a; a ...
- 递归算法(一)——akm
要求 已知akm函数如下: { n+1 while m=0 } => Rule I akm(m,n)= { akm(m-1,1) while n ...
- C# 递归算法与冒泡
C# 递归算法求 1,1,2,3,5,8,13···static void Main(string[] args){ int[] cSum = new int[10];for (int i = 0; ...
- 递归算法实现10进制到N进制的转换
#include<iostream> using namespace std; int BaseTrans(int data,int B){ int s; ) ; //结束递归算法 s=d ...
随机推荐
- BZOJ_1024_[SHOI2008]_生日快乐_(dfs)
描述 http://www.lydsy.com/JudgeOnline/problem.php?id=1024 给出一个\(x*y\)的距形,要求平行于边切,最终切成\(n\)个面积相等的小距形,求长 ...
- 【转】JAVA之动态代理
转自:像少年啦飞驰 代理设计模式 定义:为其他对象提供一种代理以控制对这个对象的访问. 代理模式的结构如下图所示. 动态代理使用 java动态代理机制以巧妙的方式实现了代理模式的设计理念. 代理模式示 ...
- (任寒韬)WebApp群主 - MobileTech 资料
web app : http://www.lightapp.cn/brand/index/4101 https://github.com/jtyjty99999/mobileTech/blob/mas ...
- LeetCode: 3SumClosest
Title : Given an array S of n integers, find three integers in S such that the sum is closest to a g ...
- 130道ASP.NET面试题
转:http://boke.25k5.com/kan88569.html 1. 简述 private. protected. public. internal 修饰符的访问权限. 答 . privat ...
- Oracle 数据乱码
原文 Oracle 数据乱码 服务器配置环境变量 NLS_LANG:American_america.ZHS16GBK
- C# chart绑定数据的方式整理
C#chart 画图曲线的条数决定是你的数据源也就Series.Series是对象 你动态创建就可以了. 一.数组, List 等简单Collection类型的方式 Series s1= new Se ...
- Android ListView从网络获取图片及文字显示
上一篇文章说的是ListView展示本地的图片以及文本,这一篇说一下如何从网络获取图片以及文本来显示.事实上,一般是先获取Josn或sml数据,然后解释显示.我们先从网上获取xml,然后对其进行解析, ...
- 火狐和google游览器的 hack独有识别 css
先来看google的: /* 这针对于webkit内核的游览器.包括苹果谷歌游览器等*/ @media screen and (-webkit-min-device-pixel-ratio:0) { ...
- ISAPI在IIS7上的配置
主要介绍ISAPI的作用.ISAPI在IIS7上的配置.开发ISAPI的基本内容及使用VS 2008配置ISAPI DLL开发项目. 一.ISAPI介绍 缩写词=Internet Server App ...