//编写代码,演示多个字符从两端移动,向中间汇聚 实现效果如下
//welcom to bit!!!!
//#################
//w###############!
//we#############!!
//wel###########!!!
//welc#########!!!!
//……
//welcom to bit!!!!
#include<stdio.h>
#include<Windows.h>
#include<stdlib.h>
int main()
{
char arr1[] = "welcom to bit!!!!";
char arr2[] = "#################";
int left = 0;
//int right = sizeof(buf) / sizeof(buf[0]) - 2;//这样计算 算上了\0 分别减去\0和因为下标是从0开始的,计算个数从1开始算的差值
int right=strlen(arr1)-1; //因为下标从0开始,strlen计算个数\0之前的元素个数,从1开始 减去数字差1
while (left<=right)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s\n", arr2);
Sleep(1000);//休眠1s 对应添加 #include<Windows.h> 头文件
//清空屏幕 使效果叠加出现在一行中
system("cls");//system是一个库函数,可以执行系统命令 cls就是执行清空屏幕的系统命令 对应添加 #include<stdlib.h> 头文件
left++;
right--;
}
printf("%s\n", arr2);
return 0;
}
我们先来定义两个数组arr1和arr2,
然后用两个值定义两端数组的序号,控制输出循环,我们分别定义为left和right
那么left和fight的值如何确定呢,
left是左边的序号,从0开始,我们定义初始值为0,后面实现++
right是最右边的序号,有以下两种方法定义,代码中都标注的详细的注释
方法1: int right=strlen(arr1)-1; //因为下标从0开始,strlen计算个数\0之前的元素个数,从1开始 减去数字差1
方法2:int right = sizeof(buf) / sizeof(buf[0]) - 2;//sizeof算上了\0 分别减去\0和因为下标是从0开始的,计算个数从1开始算的差值
right的顺序是从最有边开始的,这样我们后续实现--
下面,我们把arr1的内容赋值给arr2,也就是说,输出arr2时,不断用arr1的内容去覆盖
这样我们把这部分放入一个while循环中,来实现逐个覆盖,此时实现的效果是这样的
这样显示还存在一些改进的空间,我们下面将其进行优化
添加Sleep(1000);//休眠1s 对应添加 #include<Windows.h> 头文件
来控制输出的顺序,展示出了逐条输出的效果
此外我们还可以将其改为,在一行中逐字覆盖的效果 添加:
system("cls");//system是一个库函数,可以执行系统命令 cls就是执行清空屏幕的系统命令 对应添加 #include<stdlib.h> 头文件
可以实现,每输出一句,清空原先内容,这样便实现了逐字覆盖的效果
以上为逐个的代码分析,接下来我们再来思考一下这里面的逻辑,这里点明一个误区
比如当left=3时,arr[3]表示的时数组中的第三个值,不是前三个,那么为什么left=3时,arr[3]对应输出的是arr1的前三个值呢,是因为我们的循环逐个赋值,前面循环left=0,left=1,left=3时,已经将对应arr1的值赋值给了arr2,后面是自增,right同理,这是我在初步学习过程中的盲点和误区,理解这一点便明白了while循环及其表达效果!
其中还有这里涉及的一个小知识点注释没有标出:
`sizeof(buf)`中的`buf`是一个变量或数组名。`sizeof`是C语言中的一个操作符,用于获取某个类型或变量的大小(以字节为单位)。在这里,`buf`表示一个缓冲区的名称,用来存储数据。`sizeof(buf)`将返回缓冲区 `buf` 的大小,即它所占用的字节数。通过使用 `sizeof` 操作符,可以在编程中动态计算变量或数组的大小,以便进行后续的内存操作和管理。