当前位置: 首页 > news >正文

练习(递归)

练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;
}



http://www.jsqmd.com/news/78415/

相关文章:

  • 2025留学生求职机构TOP10:途鸽求职12年深耕“学业+就业”双轨服务,交付率98%高口碑蝉联榜首 - 资讯焦点
  • 解决canvas toDataURL跨域难题,教你配置CORS正确姿势
  • 完整教程:Vue3疑难问题全解析
  • Ice:彻底解放你的Mac菜单栏 - 免费开源管理工具完全指南
  • 2026软件测试面试题整理汇总
  • 定义GEO新标准:看深圳犀牛云如何助力企业赢取全球AI搜索先机 - 资讯焦点
  • LibreChat高危漏洞CVE-2025-66451解析:输入验证不当可导致AI对话被恶意操控
  • 专业品牌全案策划公司选哪家靠谱?奇正沐古 - 资讯焦点
  • 如何快速掌握NukeSurvivalToolkit:视觉特效制作终极实战指南
  • 【C編程】彙編語言文件
  • 国内/高速/855/1160/卧式/桥式五轴/龙门/立式加工中心那个厂家刚性好?稳定性好? - 品牌推荐大师
  • 3大核心技术揭秘:Puerts如何让UE5程序化生成效率提升500%
  • 这三种人当黑客早晚会出事:别让技术毁了前途,其实走合法路径收入更高
  • 自动化缺陷修复的建议生成:赋能软件测试新范式
  • CTF网络安全大赛_网安战队简历,零基础入门到精通,收藏这一篇就够了
  • 设计院为何陷入“三高困境”?高负荷、高流失、高风险
  • GPT-5.2大模型全方位解析:从技术优势到实战应用(建议收藏)
  • JS正则验证QQ邮箱格式,5-11位数字核心规则详解
  • Spring Boot项目优化和JVM调优 - 教程
  • Elasticsearch Bulk 写入性能问题排查实录
  • AI中的函数调用是什么?
  • AI重塑API测试数据生成的时代背景
  • YYEVA动效播放器完整使用指南:从入门到精通
  • MIT和魏茨曼研究所首次用AI大规模解密视觉皮层的秘密语言
  • 字节跳动发布GAR:让AI能像人类一样精准理解图像任何区域的技术
  • 高通量多肽合成仪安全操作及保养规程 - 品牌推荐大师
  • 物流排班到底该自研还是采购SaaS?4大核心维度揭示最佳解法
  • 基于zigbee的广告牌安全监测系统设计与实现(论文+源码)
  • 多肽药物开发:兼具双重优势的医药研发热门领域
  • 天塌了!pmp考纲再次改版,费用上涨并且新增题型?