news 2026/4/16 15:19:35

练习(递归)

作者头像

张小明

前端开发工程师

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/4/11 14:11:29

iOS 上架需要哪些材料?一份面向工程团队的完整清单与实操说明

许多团队在准备首次提交 iOS 应用时&#xff0c;最常见的问题不是技术实现&#xff0c;而是&#xff1a;“到底需要准备哪些材料&#xff1f;” App Store 提交流程本质上是一个覆盖 法律合规、图标资产、隐私说明、证书体系、构建产物 的复合工程。每项材料之间都有对应关系&a…

作者头像 李华
网站建设 2026/4/15 16:20:48

网络IP怎么反查出真实域名来?详细教程零基础入门到精通!

知道网络IP怎么反查出真实域名来&#xff1f;给大家分享几个我常用的方法&#xff0c;就算你不懂技术你都能查得出来&#xff01; 一、fofa 这是一个白帽黑客非常喜欢用的社工平台&#xff0c;只要你输入IP就能查到很多背后的信息。 传送门&#xff1a;https://fofa.info 二、…

作者头像 李华
网站建设 2026/4/2 12:11:09

C语言十进制转二进制怎么算?除2取余法原理与步骤详解

理解十进制到二进制的转换&#xff0c;是进入计算机科学领域的一块重要基石。这个过程揭示了计算机处理数字的本质逻辑&#xff0c;掌握它不仅能帮助你在编程中更好地操作数据&#xff0c;也能深化对硬件底层工作的认识。下面我将从几个关键问题入手&#xff0c;具体说明转换的…

作者头像 李华
网站建设 2026/4/16 11:49:44

图片怎么变成字符串?开发者必懂的Base64和性能技巧

在数字时代&#xff0c;图像已经超越了简单的视觉记录&#xff0c;成为信息传递、情感表达和创意实现的强大载体。从社交媒体到专业设计&#xff0c;“string图片”这一概念&#xff0c;或者说图像作为数据字符串的思维&#xff0c;正悄然改变着我们处理视觉内容的方式。这种视…

作者头像 李华
网站建设 2026/4/16 5:43:55

WeKnora v2.0革命性发布:智能文档处理进入全新时代

WeKnora v2.0革命性发布&#xff1a;智能文档处理进入全新时代 【免费下载链接】WeKnora LLM-powered framework for deep document understanding, semantic retrieval, and context-aware answers using RAG paradigm. 项目地址: https://gitcode.com/GitHub_Trending/we/W…

作者头像 李华