名人说:古之立大事者,不惟有超世之才,亦必有坚忍不拔之志。——苏轼
进度:C/C++语言100题练习计划专栏,目前16/100
🐼本篇内容简介:一、概念说明-->二、问题呈现-->三、源码实现-->四、输出结果展示-->五、流程分析
🥇C语言100题练习专栏计划:目的:巩固练习C语言,增强上机、动手实践能力,交流学习!题量随时间的增加会有所增加。前期尽量每天更新一题,之后题量随时间的增加会有所增加。中间也会插入一些算法的问题,文章内容也会不断打磨优化,争取做到好、然后更好!
C Programming Language
一、概念说明
1.字符串
1.1走进字符串
字符串简单来说,就是一串(段)字符。(听君一席话,如听一席话。)
那就举两个小例子来加深理解吧
例如
:
①"abc"
②"how are you?"
等这样的就可以作为字符串来处理。
1.2字符串处理(C语言风格)
在C语言中,字符串是以字符数组的形式进行存储的,且在数组中以’ 0 '作为终结符。
由于’0’在 ASCII 中表示 空字符 ( NULL ),即在语意上不可能有有效字符与之重复,故用其来表示字符串的结尾至少在ASCII编码下是合理的。
1.3用于何处
字符串主要用于编程,概念说明、函数解释等,具体来说像字符串连接,逆序输出字符串,一些高精度算法实现等。
2.逆序存储
2.1逆序存储
以初始序列作为顺序,逆着来存储。
2.2以例助解
例如:
顺序存储
①char a[4] = {‘a’,‘b’,‘c’,‘\0’};
②char a[]=“abc”;
逆序存储
①char a[4] = {‘c’,‘b’,‘a’,‘\0’};
②char a[]=“cba”;
二、问题呈现
1.问题描述
Problem Description
将数组中的字符串逆序存储并输出。(0<字符串长度≤20)
2.输入输出
Input
输入一个字符串。
Output
输出逆序字符串。
3.测试样例
Sample Input
abc
Sample Output
cba
三、源码实现(+注释)
#include<stdio.h>
#include<string.h>
int main()
{
int i,l,t;
//定义一个字符数组 长度大小为20
char a[20];
//gets C语言风格 输入字符串的一种方式
gets(a); //也可以写成scanf("%s",a);的形式
//strlen 存储在string函数库中,用于求解字符串的长度
l=strlen(a);
//逆序存储
for(i=0;i<l/2;i++)
{
//可以看到 以下三个语句
//很像之前排序算法中的交换语句,可以类比去理解
t=a[i];
a[i]=a[l-1-i];
a[l-1-i]=t;
}
//循环输出逆序字符串
for(i=0;i<l;i++)
printf("%c",a[i]);
printf("\n");
return 0;
}
四、输出结果展示
abc
cba
--------------------------------
Process exited after 4.257 seconds with return value 0
请按任意键继续. . .
五、流程分析
1.读题
将数组中的字符串逆序存储并输出。(0≤字符串长度≤20) 关键点:①数组中的字符串 ②逆序存储 ③字符串长度
2.构思
a.
根据关键点①数组中的字符串,可知需要定义一个字符数组,去存字符串
b.
再看关键点②,逆序存储,找到逆序存储与顺序存储之间的联系,以中间为轴,交换左右两方即可。
c.
最后关键点③,字符串长度为0到20,所以至少要定义一个长度为20的字符数组。
3.编程
把你所思所想,以代码的形式,写出来。
Code_流苏(CSDN)(一个喜欢古诗词和编程的Coder😊)
如果对大家有帮助的话,希望大家能多多点赞+关注!这样我动力会更足哦! ღ( ´・ᴗ・` )比心
友情提示:第一篇为试看内容,关注博主就可以免费观看本专栏全部内容!(*^ ▽ ^ *)