news 2026/6/15 13:41:54

练习(递归)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
练习(递归)

练1.根据下面递归函数: 调用函数Fun(2),求 返回值
int Fun(int n)
{
if (n == 5)
return 2;
else
return 2 * Fun(n + 1);
}

int main()
{
int ret = Fun(2);
printf("%d\n", ret);
return 0;
}

练2.字符串逆序(递归实现)
编写一个函数 reverse_string(char *string)(递归实现)
实现: 将参数字符串中的字符反向排列, 不是逆序打印。
要求: 不能使用C函数库中的字符串操作函数。
比如:
char arr[] = "abcdef";
逆序之后数组的内容变成: fedcba
int my_strlen(char* str)
{
int count = 0;
while (*str != '\0')
{
count++;
str++;
}
return count;
}

void reverse(char* str)
{
char tmp = *str;//1
int len = my_strlen(str);
*str = *(str + len - 1);//2
*(str+len - 1) = '\0';//3
if(my_strlen(str+1)>=2)
reverse(str+1);//4
*(str + len - 1) = tmp;
}
int main()
{
char arr[] = "abcdef";//[a b c d e f \0]
int sz = sizeof(arr) / sizeof(arr[0]);
int left = 0;
int right = sz-2;
while (left<right)
{
char tmp = arr[left];
arr[left] = arr[right];
arr[right] = tmp;
left++;
right--;
}

printf("%s\n", arr);

return 0;
}
或者
void reverse(char arr[], int left, int right)
{
char tmp = arr[left];
arr[left] = arr[right];
arr[right] = tmp;
if(left<right)
reverse(arr, left+1, right-1);
}

int main()
{
char arr[] = "abcdefg";//[a b c d e f \0]
int left = 0;
int right = my_strlen(arr)-1;
reverse(arr, left, right);
printf("%s\n", arr);

return 0;
}

练3.计算一个数的每位之和(递归实现)
题目内容:
写一个递归函数DigitSum(n),输入一个非负整数,返回组成它的数字之和
例如,调用DigitSum(1729),则应该返回1+7+2+9,它的和是19
输入: 1729,输出: 19
int DigitSum(unsigned int n)//1234
{
if (n > 9)
return DigitSum(n / 10) + n % 10;
else
return n;
}

int main()
{
unsigned int n = 0;
scanf("%u", &n);
int sum = DigitSum(n);
printf("%d\n", sum);

return 0;
}

练4.递归实现n的k次方
题目内容:
编写一个函数实现n的k次方,使用递归实现。
Pow(n,k)
├─ k>0, n*Pow(n, k-1)
├─ k == 0, 1
└─ k<0, 1.0/Pow(n, -k);
double Pow(int n, int k)
{
if (k > 0)
return n * Pow(n, k - 1);
else if (k == 0)
return 1;
else
return 1.0 / Pow(n, -k);
}

int main()
{
int n = 0;
int k = 0;
scanf("%d%d", &n, &k);
double ret = Pow(n, k);
printf("%lf\n", ret);

return 0;
}



版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 13:15:55

KeyCastr按键可视化工具:macOS屏幕录制必备神器终极指南

KeyCastr按键可视化工具&#xff1a;macOS屏幕录制必备神器终极指南 【免费下载链接】keycastr KeyCastr, an open-source keystroke visualizer 项目地址: https://gitcode.com/gh_mirrors/ke/keycastr 在屏幕录制、在线教学或技术演示过程中&#xff0c;能够清晰地展示…

作者头像 李华
网站建设 2026/6/14 3:24:08

基于SSM框架的企业人事管理系统毕业设计项目源码

题目简介基于 SSM 框架的企业人事管理系统&#xff0c;直击企业 “人事流程线下化、员工数据碎片化、决策缺乏数据支撑” 的核心痛点&#xff0c;依托 SSM 框架 “分层清晰、耦合度低、扩展性强” 的技术优势&#xff0c;构建 “人员全生命周期管理 智能协同办公” 的一体化人…

作者头像 李华
网站建设 2026/6/15 13:22:15

P1055 [NOIP 2008 普及组] ISBN 号码

前言 玩这么久洛谷&#xff0c;终于会直接复制题目的Markdown了&#x1f923; P1055 [NOIP 2008 普及组] ISBN 号码 题目描述 每一本正式出版的图书都有一个 ISBN 号码与之对应&#xff0c;ISBN 码包括 999 位数字、111 位识别码和 333 位分隔符&#xff0c;其规定格式如 x…

作者头像 李华
网站建设 2026/6/11 4:15:40

如何利用MSF远程渗透操控别人手机?一文详解。

黑客技术之MSF远程渗透操控别人手机 一、前言 MSF&#xff0c;全称为Metasploit Framework&#xff0c;是kali中一款全球知名的开源渗透测试工具。此文章中的方法只能进行内网渗透。由于kali在虚拟机中&#xff0c;其显示的内网IP无法被外网的安卓手机S直接访问&#xff0c;所…

作者头像 李华