news 2025/12/27 18:58:05

练习(递归)

作者头像

张小明

前端开发工程师

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进行投诉反馈,一经查实,立即删除!
网站建设 2025/12/12 18:24:11

Qwen3-0.6B:6亿参数引爆轻量AI革命,重塑企业智能化格局

Qwen3-0.6B&#xff1a;6亿参数引爆轻量AI革命&#xff0c;重塑企业智能化格局 【免费下载链接】Qwen3-0.6B Qwen3 是 Qwen 系列中最新一代大型语言模型&#xff0c;提供全面的密集模型和混合专家 (MoE) 模型。Qwen3 基于丰富的训练经验&#xff0c;在推理、指令遵循、代理能力…

作者头像 李华
网站建设 2025/12/22 20:29:43

深入理解Android Handler机制:从原理到进阶实战

目录 引言 一、Handler四组件架构全景 1.1 核心组件关系图 1.2 各组件核心职责 1.3 工作原理源码解析 二、Handler基础实战案例 2.1 跨线程UI更新 2.2 延迟任务与定时任务 三、IdleHandler深度解析与实战 3.1 IdleHandler核心原理 3.2 IdleHandler源码分析 3.3 IdleHandler实战…

作者头像 李华
网站建设 2025/12/12 18:22:55

Groove音乐播放器完全指南:解锁专业级音乐体验

开启你的音乐之旅 &#x1f3b5; 【免费下载链接】Groove 项目地址: https://gitcode.com/gh_mirrors/gr/Groove Groove音乐播放器是一款功能全面的开源音乐软件&#xff0c;专为追求高品质音乐体验的用户设计。它巧妙地将本地音乐管理、在线音乐探索和个性化播放功能融…

作者头像 李华
网站建设 2025/12/12 18:21:47

Omega-AI:Java开发者的终极深度学习框架,快速构建智能应用

Omega-AI&#xff1a;Java开发者的终极深度学习框架&#xff0c;快速构建智能应用 【免费下载链接】omega-ai Omega-AI&#xff1a;基于java打造的深度学习框架&#xff0c;帮助你快速搭建神经网络&#xff0c;实现模型推理与训练&#xff0c;引擎支持自动求导&#xff0c;多线…

作者头像 李华
网站建设 2025/12/18 8:40:42

【YOLO11-MM 多模态目标检测】高频感知模块(HighFrequencyPerception)频域增强小目标边缘细节纹理

摘要 本文提出了一种基于YOLO11-MM框架的多模态目标检测改进方法&#xff0c;重点针对红外与可见光融合场景下的检测性能优化。通过引入高频感知模块(HFP)&#xff0c;在频域对特征进行高通滤波处理&#xff0c;突出小目标的纹理与边缘信息&#xff0c;并采用通道与空间注意力…

作者头像 李华