加载中…
个人资料
  • 博客等级:
  • 博客积分:
  • 博客访问:
  • 关注人气:
  • 获赠金笔:0支
  • 赠出金笔:0支
  • 荣誉徽章:
正文 字体大小:

学中枢前的准备理论之一

(2009-09-05 19:43:42)
标签:

if

move

procedure

边界条件

t1

杂谈

分类: 缠论股票课程
  一、中枢
  事物系统中起中心主导作用的部分      
   二、递归
    第一、概述
  递归做为一种算法在程序设计语言中广泛应用.是指函数/过程/子程序在运行过程序中直接或间接调用自身而产生的重入现像.
  程序调用自身的编程技巧称为递归( recursion)。
  一个过程或函数在其定义或说明中又直接或间接调用自身的一种方法,它通常把一个大型复杂的问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的程序就可描述出解题过程所需要的多次重复计算,大大地减少了程序的代码量。递归的能力在于用有限的语句来定义对象的无限集合。用递归思想写出的程序往往十分简洁易懂。
  一般来说,递归需要有边界条件、递归前进段和递归返回段。当边界条件不满足时,递归前进;当边界条件满足时,递归返回。
  注意:
  (1) 递归就是在过程或函数里调用自身;
  (2) 在使用递归策略时,必须有一个明确的递归结束条件,称为递归出口。
  递归算法一般用于解决三类问题:
  (1)数据的定义是按递归定义的。(Fibonacci函数)
  (2)问题解法按递归算法实现。(回溯)
  (3)数据的结构形式是按递归定义的。(树的遍历,图的搜索)
  递归的缺点:
  递归算法解题的运行效率较低。在递归调用的过程当中系统为每一层的返回点、局部量等开辟了栈来存储。递归次数过多容易造成栈溢出等。
  例子:
  #include <iostream.h>
  void move (char getone,char putone)
  {
  cout <<getone<<"-->"<}
  void hanoi(int n,char one ,char two ,char three)
  {
  void move (char getone,char putone );
  if (n==1)
  move (one,three);
  else
  {
  hanoi(n-1,one,three,two);
  move (one ,three);
  hanoi(n-1,two,one,three);
  }
  }
  void main()
  {
  void hanoi(int n ,char one ,char two ,char three);
  int m ;
  cout <<"Input the numberof disker:";
  cin>>m;
  cout<<"the steps to moving "<<m<<"diskes
  :"<<endl;
  hanoi(m,'A','B','C');
  }
  第二、递归
  2.1 递归的概念
  2.2 如何设计递归算法
  2.3 典型例题
  递归是计算机科学的一个重要概念,递归的方法是程序设计中有效的方法,采用递归编写
  程序能是程序变得简洁和清晰.
  2.1 递归的概念
  1.概念
  一个过程(或函数)直接或间接调用自己本身,这种过程(或函数)叫递归过程(或函数).
  如:
  procedure a;
  begin
  .
  .
  .
  a;
  .
  .
  .
  end;
  这种方式是直接调用.
  又如:
  procedure b; procedure c;
  begin begin
  . .
  . .
  . .
  c; b;
  . .
  . .
  . .
  end; end;
  这种方式是间接调用.
  例1计算n!可用递归公式如下:
  1 当 n=0 时
  fac(n)={n*fac(n-1) 当n>0时
  可编写程序如下:
  program fac2;
  var
  n:integer;
  function fac(n:integer):real;
  begin
  if n=0 then fac:=1 else fac:=n*fac(n-1)
  end;
  begin
  write('n=');readln(n);
  writeln('fac(',n,')=',fac(n):6:0);
  end.
  例2 楼梯有n阶台阶,上楼可以一步上1阶,也可以一步上2阶,编一程序计算共有多少种不同的走法.
  设n阶台阶的走法数为f(n)
  显然有
  1 n=1
  f(n)={2 n=2
  f(n-1)+f(n-2) n>2
  可编程序如下:
  program louti;
  var n:integer;
  function f(x:integer):integer;
  begin
  if x=1 then f:=1 else
  if x=2 then f:=2 else f:=f(x-1)+f(x-2);
  end;
  begin
  write('n=');read(n);
  writeln('f(',n,')=',f(n))
  end.
  

0

阅读 收藏 喜欢 打印举报/Report
  

新浪BLOG意见反馈留言板 欢迎批评指正

新浪简介 | About Sina | 广告服务 | 联系我们 | 招聘信息 | 网站律师 | SINA English | 产品答疑

新浪公司 版权所有