递归C++

一、递归简介

自己调用自己

二、递归写法

2.1 写法介绍

先写出问题的递推公式

递归部分的边界条件就是递推公式中的边界条件

递归部分的主体部分就是递推公式中的主体部分

2.2 实例

(1)题目

例如:求n!。

(2)分析

递归公式为 f(n)=f(n-1)*n f(1)=1;

对应的递归:

 /*
阶乘递归
递归公式为 f(n)=f(n-1)*n f(1)=1;
递归部分的边界条件就是递推公式中的边界条件 f(1)=1
递归部分的主体部分就是递推公式中的主体部分 f(n)=f(n-1)*n
*/
int factorial_Recursion(int n){
if(n==) return ;
else return factorial_Recursion(n-)*n;
}

(3)完整代码

 #include <iostream>
using namespace std; int factorial(int n);
int factorial_Recursion(int n); /*
阶乘非递归
*/
int factorial(int n){
int ans=;
for(int i=;i<=n;i++){
ans*=i;
}
return ans;
} /*
阶乘递归
递归公式为 f(n)=f(n-1)*n f(1)=1;
递归部分的边界条件就是递推公式中的边界条件 f(1)=1
递归部分的主体部分就是递推公式中的主体部分 f(n)=f(n-1)*n
*/
int factorial_Recursion(int n){
if(n==) return ;
else return factorial_Recursion(n-)*n;
} int main(){
int ans;
//ans=factorial(5);
ans=factorial_Recursion();
printf("%d\n",ans);
return ;
}

(4)代码结果

120

三、递归实例

3.1 辗转相除法求公约数

递推公式:f(a,b)=f(b,a%b) b!=0;

代码:

 #include <iostream>
using namespace std; void exchange(int &a,int &b);
int commonDivisor(int a,int b);
int commonDivisor_Recursion(int a,int b); /*
交换a和b两个数的值
*/
void exchange(int &a,int &b){
a=a^b;
b=a^b;
a=a^b;
} /*
非递归辗转相除法求公约数:
用辗转相除法的时候要保证a大于等于b
*/
int commonDivisor(int a,int b){
if(b>a) exchange(a,b);
int tmp=a%b;
while(tmp){
a=b;
b=tmp;
tmp=a%b;
}
return b;
} /*
递归辗转相除法求公约数:
用辗转相除法的时候要保证a大于等于b
递推公式:f(a,b)=f(b,a%b) b!=0;
边界条件为: b!=0
递归主体为: f(a,b)=f(b,a%b)
*/
int commonDivisor_Recursion(int a,int b){
if(a%b==) return b;
else commonDivisor_Recursion(b,a%b);
} int main(){
int ans;
//ans=commonDivisor(15,9);
ans=commonDivisor_Recursion(,);
printf("%d\n",ans);
return ;
}

代码结果:

3

3.2 判断和相等

题目:

已知一个一维数组a[1...n]和一个确定的数m,判断能否使数组a中的任意几个元素之和等于m,能则输出YES,不能则输出NO。

分析:

分为取a[n]和不取a[n]的情况,则递推公式为:

f(n,m)=f(n-1,m-a[n])||f(n-1,m)

这里可以用一个全局变量来输出结果,只有有一种情况满足了,就满足了。

这个题目没完,后面要补。

递归C++的更多相关文章

  1. .NET 基础 一步步 一幕幕[面向对象之方法、方法的重载、方法的重写、方法的递归]

    方法.方法的重载.方法的重写.方法的递归 方法: 将一堆代码进行重用的一种机制. 语法: [访问修饰符] 返回类型 <方法名>(参数列表){ 方法主体: } 返回值类型:如果不需要写返回值 ...

  2. 算法笔记_013:汉诺塔问题(Java递归法和非递归法)

    目录 1 问题描述 2 解决方案  2.1 递归法 2.2 非递归法 1 问题描述 Simulate the movement of the Towers of Hanoi Puzzle; Bonus ...

  3. Android 算法 关于递归和二分法的小算法

     // 1. 实现一个函数,在一个有序整型数组中二分查找出指定的值,找到则返回该值的位置,找不到返回 -1. package demo; public class Mytest { public st ...

  4. 二叉树的递归实现(java)

    这里演示的二叉树为3层. 递归实现,先构造出一个root节点,先判断左子节点是否为空,为空则构造左子节点,否则进入下一步判断右子节点是否为空,为空则构造右子节点. 利用层数控制迭代次数. 依次递归第二 ...

  5. 递归实现n(经典的8皇后问题)皇后的问题

    问题描述:八皇后问题是一个以国际象棋为背景的问题:如何能够在8×8的国际象棋棋盘上放置八个皇后, 使得任何一个皇后都无法直接吃掉其他的皇后?为了达到此目的,任两个皇后都不能处于同一条横行.纵行或斜线上 ...

  6. C语言用分别用递归和循环求数字的阶乘的方法

    以下代码均为 自己 实现,嘻嘻! 参考文章:http://blog.csdn.net/talk_8/article/details/46289683 循环法 int CalFactorial(int ...

  7. C#递归解决汉诺塔问题(Hanoi)

    using System;using System.Collections.Generic;using System.Linq;using System.Text; namespace MyExamp ...

  8. Java之递归求和的两张方法

    方法一: package com.smbea.demo; public class Student { private int sum = 0; /** * 递归求和 * @param num */ ...

  9. C#语言基础——递归

    递归 一.概念conception: 函数体内调用本函数自身,直到符合某一条件不再继续调用. 二.应满足条件factor: (1)有反复执行的过程(调用自身): (2)有跳出反复执行过程的条件(函数出 ...

  10. SQL Server封闭掉 触发器递归

    SQL Server关闭掉 触发器递归SQL Server  是有一个开关, 可以关闭掉 触发器递归的.EXEC sp_dboption '数据库名字', 'recursive triggers', ...

随机推荐

  1. yii2redis安装

    yii2 – redis 配置 转自:http://www.fancyecommerce.com/2016/05/03/yii2-redis-%E9%85%8D%E7%BD%AE/ 安装redis w ...

  2. ASCII说明和ASCII对照表

    ASCII 说明 ASCII 码使用指定的 7 位或 8 位二进制数组合来表示 128 或 256 种可能的字符.标准 ASCII 码也叫基础ASCII码,使用 7 位二进制数来表示所有的大写和小写字 ...

  3. 论文笔记:语音情感识别(四)语音特征之声谱图,log梅尔谱,MFCC,deltas

    一:原始信号 从音频文件中读取出来的原始语音信号通常称为raw waveform,是一个一维数组,长度是由音频长度和采样率决定,比如采样率Fs为16KHz,表示一秒钟内采样16000个点,这个时候如果 ...

  4. 1.hive开窗函数,分析函数

    http://yugouai.iteye.com/blog/1908121 分析函数用于计算基于组的某种聚合值,它和聚合函数的不同之处是:对于每个组返回多行,而聚合函数对于每个组只返回一行.开窗函数指 ...

  5. linux常用命令:chgrp 命令

    在 lunix系统里,文件或目录的权限的掌控以拥有者及所诉群组来管理.可以使用chgrp指令变更文件与目录所属群组,这种方式采用群组名称或群组识别 码都可以.chgrp命令就是change group ...

  6. 计算概论(A)/基础编程练习1(8题)/6:判断闰年

    #include<stdio.h> int isLeap(int year) { // 必须先判断是平年的情况 后判断闰年的情况 == && year%!=) || yea ...

  7. MySQL Crash Course #06# Chapter 13. 14 GROUP BY. 子查询

    索引 理解 GROUP BY 过滤数据 vs. 过滤分组 GROUP BY 与 ORDER BY 之不成文的规定 子查询 vs. 联表查询 相关子查询和不相关子查询. 增量构造复杂查询 Always ...

  8. python 线程 进程 协程 学习

    转载自大神博客:http://www.cnblogs.com/aylin/p/5601969.html 仅供学习使用···· python 线程与进程简介 进程与线程的历史 我们都知道计算机是由硬件和 ...

  9. vijos 1098 合唱队形 - 动态规划

    描述 N位同学站成一排,音乐老师要请其中的(N-K)位同学出列,使得剩下的K位同学排成合唱队形. 合唱队形是指这样的一种队形:设K位同学从左到右依次编号为1,2…,K,他们的身高分别为T1,T2,…, ...

  10. 【转】各种消息下wParam及lParam值的含义

    转载自:http://bbs.fishc.com/forum.php?mod=viewthread&tid=52668#lastpost 01.WM_PAINT消息 LOWORD(lParam ...