C语言100题练习计划 39——递归实现翻转字符串

名人说:长风破浪会有时,直挂云帆济沧海。——李白
进度:C/C++语言100题练习计划专栏,目前39/100

🐼本篇内容简介一、问题呈现-->二、源码实现(+详细注释)-->三、输出结果展示

🥇C语言100题练习专栏计划目的:巩固练习C语言,增强上机、动手实践能力,交流学习!题量随时间的增加会有所增加。中间也会插入一些算法的问题,文章内容也会不断打磨、精简优化,争取做到好、然后更好!

一、问题呈现

1.问题描述

Problem Description

借助递归及其他知识,编程实现字符串的翻转(反向排列)。

2.输入输出

Input

输入一个字符串

Output

输出该字符串翻转后的结果

3.测试样例
样例1

Sample Input

abc

Sample Output

cba

样例2

Sample Input

abcde

Sample Output

edcba

二、源码实现(+详细注释)

//编码及注释:Code_流苏
//定义头文件
#include <stdio.h>
#include <stdlib.h>
//翻转字符串函数
void Reverse_String(char * str)
//*str传递的是字符串首地址
{
	//如果对应字符串地址中的字符非'\0' 
	if(*(++str) != '\0')
	{
		//递归翻转
		Reverse_String(str);
	}
	//输出翻转的字符
	printf("%c", *(str - 1));
}
//主函数
int main()
{
	//定义字符串s
	char s[100];
	//输出提示
	printf("请输入翻转前的字符串:");
	//输入字符串s
	scanf("%s",s);
	//输出提示
	printf("翻转后的字符串:");
	//调用翻转字符串函数
	Reverse_String(s);
	//输出换行
	printf("\n");
	//如果正常返回0 说明程序执行成功 非0 则有出错或异常
	return 0;
}

关于递归的理解,之前个人总结的有一篇文章,大家可作参考递归

三、输出结果展示

请输入翻转前的字符串:abc
翻转后的字符串:cba

--------------------------------
Process exited after 1.78 seconds with return value 0
请按任意键继续. . .

以"历尽千帆 ,不坠青云!",以此共勉。

Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊)
如果对大家有帮助的话,希望大家能多多点赞+关注!这样我动力会更足哦! ღ( ´・ᴗ・` )比心
友情提示:第一篇为试看内容,关注博主就可以免费观看本专栏全部内容!(*^ ▽ ^ *)

  • 2
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Code_流苏

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值