c++2(循环和递归)

其实编程的朋友知道,不管学什么语言,循环和递归是两个必须学习的内容。当然,如果循环还好理解一点,那么递归却没有那么简单。我们曾经对递归讳莫如深,但是我想告诉大家的是,递归其实没有那么可怕。所谓的递归就是函数自己调用自己而已,循环本质上也是一种递归。

 1)求和递归函数

我们可以举一个循环的例子,前面我们说过,如果编写一个1到n的求和函数怎么写呢,你可能会这么写:

int calculate(int m)
{
	int count = 0;
	if(m <0)
		return -1;

	for(int index = 0; index <= m; index++)
		count += index;

	return count;
}

上面只是一个示范。下面我们看看如果是递归应该怎么写呢?

int calculate(int m)
{
	if(m == 0)
		return 0;
	else
		return calculate(m -1) + m;
}

大家看着两段代码有什么不同?

(1)第一段代码从0,开始计算,从0到m逐步计算;第二段代码是从10开始计算,逐步到0之后这回,这样同样可以达到计算的效果

(2)第一段代码不需要重复的压栈操作,第二段需要重复的函数操作,当然这也是递归的本质

(3)第一段代码比较长,第二段代码较短

 2)查找递归函数

大家可能说,这些代码有些特殊。如果是查找类的函数,有没有可能修改成递归函数呢?

int find(int array[], int length, int value)
{
	int index = 0;
	if(NULL == array || 0 == length)
		return -1;

	for(; index < length; index++)
	{
		if(value == array[index])
			return index;
	}

	return -1;
}

大家可能说,这样的代码可能修改成这样的代码:

int _find(int index, int array[], int length, int value)
{
	if(index == length)
		return -1;

	if(value == array[index])
		return index;

	return _find(index + 1,  array, length, value);
}

int find(int array[], int length, int value)
{
	if(NULL == array || length == 0)
		return -1;

	return _find(0, array, length, value);
}

3) 指针变量遍历

结构指针是我们喜欢的遍历结构,试想如果有下面定义的数据结构:

typedef struct _NODE
{
	int data;
	struct _NODE* next;
}NODE;

那么,此时我们需要对一个节点链接中的所有数据进行打印,应该怎么办呢?大家可以自己先想想,然后看看我们写的代码对不对。

void print(const NODE* pNode)
{
	if(NULL == pNode)
		return;

	while(pNode){
		printf("%d\n", pNode->data);
		pNode = pNode->next;
	}
}

那么此时如果改成递归,那就更简单了:

void print(const NODE* pNode)
{
	if(NULL == pNode)
		return;
	else
	    printf("%d\n", pNode->data);

	print(pNode->next);
}

其实,写这么多,就是想和大家分享一下我个人的观点:循环是一种特殊的递归,只有递归和堆栈是等价的。所有的递归代码都可以写成堆栈的形式,下面的一片博客我们就讨论一下堆栈和递归的关系。要想写好,必须熟练掌握堆栈。

时间: 2024-11-05 22:56:50

c++2(循环和递归)的相关文章

Atitit &#160;循环(loop), 递归(recursion), 遍历(traversal), 迭代(iterate).

Atitit  循环(loop), 递归(recursion), 遍历(traversal), 迭代(iterate). 1.1. 循环算是最基础的概念, 凡是重复执行一段代码, 都可以称之为循环. 大部分的递归, 遍历, 迭代, 都是循环.1 1.2. 递归的定义是, 根据一种(几种)基本情况定义的算法, 其他复杂情况都可以被逐步还原为基本情况.1 1.3. 递归的基本概念和特点1 1.4. 迭代(数学): 在循环的基础上, 每一次循环, 都比上一次更为接近结果.2 1.5. 编程语言中的循环

算法学习之循环和递归

[摘要] 大家都知道递归的实现是通过调用函数本身,函数调用的时候,每次调用时要做地址保存,参数传递等,这是通过一个递归工作栈实现的.原理上讲,所有递归都是可以消除的,代价就是可能自己要维护一个栈.而且我个人认为,很多情况下用递归还是必要的,它往往能把复杂问题分解成更为简单的步骤,而且很能反映问题的本质.循环和递归其实存在一定的联系.  1)求和递归函数 我们可以举一个循环的例子,前面我们说过,如果编写一个1到n的求和函数怎么写呢,你可能会这么写: int calculate(int m) { i

一步一步写算法(之循环和递归)

原文:一步一步写算法(之循环和递归) [ 声明:版权所有,欢迎转载,请勿用于商业用途.  联系信箱:feixiaoxing @163.com] 其实编程的朋友知道,不管学什么语言,循环和递归是两个必须学习的内容.当然,如果循环还好理解一点,那么递归却没有那么简单.我们曾经对递归讳莫如深,但是我想告诉大家的是,递归其实没有那么可怕.所谓的递归就是函数自己调用自己而已,循环本质上也是一种递归.  1)求和递归函数 我们可以举一个循环的例子,前面我们说过,如果编写一个1到n的求和函数怎么写呢,你可能会

codevs http://www.codevs.cn/problem/?problemset_id=1 循环、递归、stl复习题

12.10高一练习题 1.要求: 这周回顾复习的内容是循环.递归.stl. 不要因为题目简单就放弃不做,现在就是练习基础. 2.练习题: (1)循环   题目解析与代码见随笔分类  NOI题库 http://noi.openjudge.cn/ch0106/    10-15题 http://noi.openjudge.cn/ch0105/     37-45题 http://noi.openjudge.cn/ch0107/     28-35题 (2)递归   题目解析与代码见随笔分类 递归 h

二分查找【循环和递归】

对一个数组a,在区间下标[x,y]寻找p是否存在,存在则返回下标,否则返回-1. 循环和递归实现:(练习用的程序) 1 #include <stdio.h> 2 #include<stdlib.h> 3 #include<time.h> 4 5 int binSerrch(int a[],int x,int y,int p);//在非递减数组a的x到y区间寻找p,假如存在则返回p的下标,否则返回-1 6 int binSerrch2(int a[],int x,int

二叉树的三种遍历方式的循环和递归的实现方式

///////////////////头文件:BST.h//////////////////////// #ifndef BST_H #define BST_H #include "StdAfx.h" #include<iostream> #include<stack> template<typename DataType> class BST { public: class Node { public: Node(int data=0):m_dat

数据结构和算法学习二,之循环和递归

引自:http://blog.csdn.net/feixiaoxing/article/details/6838362 其实编程的朋友知道,不管学什么语言,循环和递归是两个必须学习的内容.当然,如果循环还好理解一点,那么递归却没有那么简单.我们曾经对递归讳莫如深,但是我想告诉大家的是,递归其实没有那么可怕.所谓的递归就是函数自己调用自己而已,循环本质上也是一种递归.  1)求和递归函数 我们可以举一个循环的例子,前面我们说过,如果编写一个1到n的求和函数怎么写呢,你可能会这么写: int cal

4.2分别使用循环和递归两种策略求二项式从c(n,k);

//4.2分别使用循环和递归两种策略求二项式从c(n,k); //以for循环运行c(n,k) #include <iostream> using namespace std; int sum(int m); int main() { int n,k; int sum_n,sum_k,sum_i,sum_n_k; cout<<"请输入C(n,k)中的n值:"<<endl; cin>>n; cout<<"请输入C(n,

3循环与递归

循环设计中要注意算法的效率: 循环体的特点是:"以不变应万变". 所谓"不变"是指循环体内运算的表现形式是不变的,而每次具体的执行内容却是不尽相同的.在循环体内用不变的运算表现形式去描述各种相似的重复运算. [例1]求1/1!-1/3!+1/5!-1/7!+-+(-1)n+1/(2n-1)! 分析:此问题中既有累加又有累乘,准确地说累加的对象是累乘的结果. 数学模型1:Sn=Sn-1+(-1)n+1/(2n-1)! 算法设计1:多数初学者会直接利用题目中累加项通式,