名人说:长风破浪会有时,直挂云帆济沧海。——李白
进度: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😊)
如果对大家有帮助的话,希望大家能多多点赞+关注!这样我动力会更足哦! ღ( ´・ᴗ・` )比心
友情提示:第一篇为试看内容,关注博主就可以免费观看本专栏全部内容!(*^ ▽ ^ *)