2.11:递归操作

2024-02-15 20:28
文章标签 操作 递归 2.11

本文主要是介绍2.11:递归操作,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

1.递归实现n!

程序代码:

  1 #include<stdio.h>2 #include<string.h>3 #include<stdlib.h>4 int fun(int n);5 int main(int argc, const char *argv[])6 {7     int n;8     printf("please enter n:");9     scanf("%d",&n);10     if(n<1)11         printf("enter error\n");12     else13     {14         int s=fun(n);15         printf("%d!=%d\n",n,s);16     }17     return 0;18 }19 int fun(int n)20 {   21     if(n==0)22         return 1;23     else24         return n*fun(n-1);25 }  

运行结果:

2.递归实现0-n的和

程序代码:

  1 #include<stdio.h>2 #include<string.h>3 #include<stdlib.h>4 int fun(int n);5 int main(int argc, const char *argv[])6 {7     int n;8     printf("please enter n:");9     scanf("%d",&n);10     if(n<0)11         printf("enter error\n");12     else13     {14         int sum=fun(n);15         printf("sum=%d\n",sum);16     }17     return 0;18 }19 int fun(int n)20 {21     if(n==0)22         return 0;23     else24         return n+fun(n-1);25 }

运行结果:

3.递归实现斐波那契数列

程序代码:

  1 #include<stdio.h>2 #include<string.h>3 #include<stdlib.h>4 int fun(int n);5 int main(int argc, const char *argv[])6 {   7     int n;8     printf("please enter n:");9     scanf("%d",&n);10     int s=fun(n);11     printf("sum=%d\n",s);12     return 0;13 }14 int fun(int n)15 {   16     if(n<=0)17     {   18         printf("enter error\n");19         return -1;20     }21     else if(n==1||n==2)22         return 1;23     else24         return fun(n-1)+fun(n-2);25 }  

运行结果:

4.递归实现二进制转换

程序代码:

  1 #include<stdio.h>2 #include<string.h>3 #include<stdlib.h>4 int rev(int num);5 int main(int argc, const char *argv[])6 {   7     int num;8     printf("please enter num:");9     scanf("%d",&num);10     rev(num);11     puts("");12     return 0;13 }14 int rev(int num)15 {16     if(num==0)17         return 0;18     else19     {20         rev(num/2);21         printf("%d",num%2);22     }23 } 

运行结果:

5.递归实现计算各个位数字之和

程序代码:

  1 #include<stdio.h>2 #include<string.h>3 #include<stdlib.h>4 int fun(int num);5 int main(int argc, const char *argv[])6 {   7     int num;8     printf("please enter num:");9     scanf("%d",&num);10     int s=fun(num);11     printf("sum=%d\n",s);12     return 0;13 }14 int fun(int num)15 {   16     if(num==0) 17         return 0;18     else19         return num%10+fun(num/10);20 }  

运行结果:

6.递归实现计算各个位数字的乘积

程序代码:

  1 #include<stdio.h>2 #include<string.h>3 #include<stdlib.h>4 int fun(int n);5 int main(int argc, const char *argv[])6 {   7     int n;8     printf("please enter n:");9     scanf("%d",&n);10     if(n==0)11         printf("%d",n);12     else13     {   14         int s=fun(n);15         printf("sum=%d\n",s);16     }17     return 0;18 }19 int fun(int n)20 {   21     if(n>=0&&n<=9)22         return n;23     else24         return n%10*fun(n/10);25 }    

运行结果:

7.递归实现计算单词逆置

程序代码:

  1 #include<stdio.h>2 #include<string.h>3 #include<stdlib.h>4 void rev(char *i,char *j);5 int main(int argc, const char *argv[])6 {7     char str[40]="";8     printf("please enter str:");9     gets(str);10     //单词计数11     int num=0,word=0;12     char c;13     for(int i=0;(c=str[i])!='\0';i++)14     {15         if(c==' ')16             word=0;17         else if(word==0)18         {19             word=1;20             num++;21         }22     }23     printf("word num=%d\n",num);24     //单词逆置25     char *end=str;26     rev(str,str+strlen(str)-1);27     while(*end!='\0')28     {29         char *start=end;30         while(*end!=' '&&*end!='\0')31             end++;32         rev(start,end-1);//单词逆置33         if(*end!='\0')34             end++;35     }36     printf("%s",str);37     puts("");38     return 0;39 }40 void rev(char *i,char *j)41 {42     while(i<j)43     {44         char t=*i;*i=*j;*j=t;45         i++;j--;46     }47 } 

运行结果:

这篇关于2.11:递归操作的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/712449

相关文章

Git可视化管理工具(SourceTree)使用操作大全经典

《Git可视化管理工具(SourceTree)使用操作大全经典》本文详细介绍了SourceTree作为Git可视化管理工具的常用操作,包括连接远程仓库、添加SSH密钥、克隆仓库、设置默认项目目录、代码... 目录前言:连接Gitee or github,获取代码:在SourceTree中添加SSH密钥:Cl

使用Java将各种数据写入Excel表格的操作示例

《使用Java将各种数据写入Excel表格的操作示例》在数据处理与管理领域,Excel凭借其强大的功能和广泛的应用,成为了数据存储与展示的重要工具,在Java开发过程中,常常需要将不同类型的数据,本文... 目录前言安装免费Java库1. 写入文本、或数值到 Excel单元格2. 写入数组到 Excel表格

Python中pywin32 常用窗口操作的实现

《Python中pywin32常用窗口操作的实现》本文主要介绍了Python中pywin32常用窗口操作的实现,pywin32主要的作用是供Python开发者快速调用WindowsAPI的一个... 目录获取窗口句柄获取最前端窗口句柄获取指定坐标处的窗口根据窗口的完整标题匹配获取句柄根据窗口的类别匹配获取句

Python位移操作和位运算的实现示例

《Python位移操作和位运算的实现示例》本文主要介绍了Python位移操作和位运算的实现示例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一... 目录1. 位移操作1.1 左移操作 (<<)1.2 右移操作 (>>)注意事项:2. 位运算2.1

Python ZIP文件操作技巧详解

《PythonZIP文件操作技巧详解》在数据处理和系统开发中,ZIP文件操作是开发者必须掌握的核心技能,Python标准库提供的zipfile模块以简洁的API和跨平台特性,成为处理ZIP文件的首选... 目录一、ZIP文件操作基础三板斧1.1 创建压缩包1.2 解压操作1.3 文件遍历与信息获取二、进阶技

Java中字符串转时间与时间转字符串的操作详解

《Java中字符串转时间与时间转字符串的操作详解》Java的java.time包提供了强大的日期和时间处理功能,通过DateTimeFormatter可以轻松地在日期时间对象和字符串之间进行转换,下面... 目录一、字符串转时间(一)使用预定义格式(二)自定义格式二、时间转字符串(一)使用预定义格式(二)自

Java字符串操作技巧之语法、示例与应用场景分析

《Java字符串操作技巧之语法、示例与应用场景分析》在Java算法题和日常开发中,字符串处理是必备的核心技能,本文全面梳理Java中字符串的常用操作语法,结合代码示例、应用场景和避坑指南,可快速掌握字... 目录引言1. 基础操作1.1 创建字符串1.2 获取长度1.3 访问字符2. 字符串处理2.1 子字

Python 中的 with open文件操作的最佳实践

《Python中的withopen文件操作的最佳实践》在Python中,withopen()提供了一个简洁而安全的方式来处理文件操作,它不仅能确保文件在操作完成后自动关闭,还能处理文件操作中的异... 目录什么是 with open()?为什么使用 with open()?使用 with open() 进行

Linux ls命令操作详解

《Linuxls命令操作详解》通过ls命令,我们可以查看指定目录下的文件和子目录,并结合不同的选项获取详细的文件信息,如权限、大小、修改时间等,:本文主要介绍Linuxls命令详解,需要的朋友可... 目录1. 命令简介2. 命令的基本语法和用法2.1 语法格式2.2 使用示例2.2.1 列出当前目录下的文

C语言函数递归实际应用举例详解

《C语言函数递归实际应用举例详解》程序调用自身的编程技巧称为递归,递归做为一种算法在程序设计语言中广泛应用,:本文主要介绍C语言函数递归实际应用举例的相关资料,文中通过代码介绍的非常详细,需要的朋... 目录前言一、递归的概念与思想二、递归的限制条件 三、递归的实际应用举例(一)求 n 的阶乘(二)顺序打印