C语言:编写代码,演示多个字符从两端移动,向中间汇聚

简介: 题目:给出第一个字符串,如:"welcome to school!!!!!",设置第二个字符串:"######################",

题目:

给出第一个字符串,如:"welcome to school!!!!!"

设置第二个字符串"######################"

两字符串字符数相等

第二个字符串两端开始移动向中间汇聚慢慢显示出第一个字符串

如:


"######################"



"we##################!!"



"welcome##########ol!!!!!"



……



“welcome to##chool!!!!!”



"welcome to school!!!!!"

思路:

总体思路:

总体思路:

(一). 生成题目要求的两个字符串定义左右下标

             

(二). 利用while循环将第二个字符串慢慢从左右两端向中间汇聚显示出第一个循环

             

(三). 使用 Sleep()函数system()函数进行优化

第一步:

(1). 生成第一个字符串 arr1 "welcome to school!!!!!"

第二个字符串 arr2 "######################"

两字符串字符数相等                

(2). 定义左右下标left right

                     

实现代码:

#include <stdio.h>
int main()
{
  //生成第一个字符串arr1:
  char arr1[] = "welcome to school!!!!!";
  //生成第二个字符串arr2:
  char arr2[] = "######################";
  //定义左右小标:left 和 right
  int left = 0;
  int right = strlen(arr1) - 1;
  //strlen(数组名称):求数组的长度,计算字符数组中\0前有多少个字符
  //数组长度 - 1 = 最右端下标 
  return 0;
}

实现图片:

9adbeb9ac6dd47bfa54b72a697311488.png

第二步:

(1). 使用while循环结合左右下标进行循环替换

                   

(2). 利用左右下标将 arr1 左右两端的值付给 arr2 左右两端的值

                 

(3). 打印重新赋值后的arr2,

                   

(4). 调整左右下标,以便下次循环改变下一对左右两端的值。

                     

实现代码:

#include <stdio.h>
int main()
{
  //生成第一个字符串arr1:
  char arr1[] = "welcome to school!!!!!";
  //生成第二个字符串arr2:
  char arr2[] = "######################";
  //定义左右小标:left 和 right
  int left = 0;
  int right = strlen(arr1) - 1;
  //strlen(数组名称):求数组的长度,计算字符数组中\0前有多少个字符
  //数组长度 - 1 = 最右端下标 
  //使用while循环结合左右下标进行循环替换
  while (left <= right)
  //如果 left > right 说明数组中左右下标之间已经没有值了
  //有值就一直循环到没有值
  {
    //利用左右下标将 arr1 左右两端的值赋给 arr2 左右两端的值
    arr2[left] = arr1[left];//将arr1左边的值 赋给 arr2左边的值
    arr2[right] = arr1[right];//将arr2右边的值 赋给 arr2右边的值
    //打印重新赋值后的arr2:
    printf("%s\n", arr2);
    //调整左右下标,以便下次循环改变下一对左右两端的值:
    left++; //调整左下标
    right--; //调整右下标
  }
  return 0;
}

实现图片:

image.png

第三步:

(1). 使用 Sleep()函数 进行优化:休眠一段时间再执行该函数后面的语句

需要 头文件<windows.h>

使用该函数防止编译器执行太快不利于观察结果

(2). 使用 system()函数 进行优化:system()函数可以执行系统命令

system("cls") 清理屏幕

这里是为了打印一句信息就清理该信息实现类似动态的效果

实现代码:

#include <stdio.h>
#include <windows.h>
int main()
{
  //生成第一个字符串arr1:
  char arr1[] = "welcome to school!!!!!";
  //生成第二个字符串arr2:
  char arr2[] = "######################";
  //定义左右小标:left 和 right
  int left = 0;
  int right = strlen(arr1) - 1;
  //strlen(数组名称):求数组的长度,计算字符数组中\0前有多少个字符
  //数组长度 - 1 = 最右端下标 
  //使用while循环结合左右下标进行循环替换
  while (left <= right)
  //如果 left > right 说明数组中左右下标之间已经没有值了
  //有值就一直循环到没有值
  {
    //利用左右下标将 arr1 左右两端的值赋给 arr2 左右两端的值
    arr2[left] = arr1[left];//将arr1左边的值 赋给 arr2左边的值
    arr2[right] = arr1[right];//将arr2右边的值 赋给 arr2右边的值
    //打印重新赋值后的arr2:
    printf("%s\n", arr2);
    //使用Sleep()函数进行优化:
    Sleep(1000);//休眠1000毫秒,即1秒,再执行后面的语句,需要头文件:<windows.h>
    //使用system()函数进行优化:
    system("cls");//清理屏幕
    //调整左右下标,以便下次循环改变下一对左右两端的值:
    left++; //调整左下标
    right--; //调整右下标
  }
  return 0;
}

实现图片:

df02210667e241ed9ffa13aa3607dd71.png

第四步:

赋值完后,arr2被system(cls)清除了,所以出循环后再打印一次arr2

                   

实现代码:

#include <stdio.h>
#include <windows.h>
int main()
{
  //生成第一个字符串arr1:
  char arr1[] = "welcome to school!!!!!";
  //生成第二个字符串arr2:
  char arr2[] = "######################";
  //定义左右小标:left 和 right
  int left = 0;
  int right = strlen(arr1) - 1;
  //strlen(数组名称):求数组的长度,计算字符数组中\0前有多少个字符
  //数组长度 - 1 = 最右端下标 
  //使用while循环结合左右下标进行循环替换
  while (left <= right)
  //如果 left > right 说明数组中左右下标之间已经没有值了
  //有值就一直循环到没有值
  {
    //利用左右下标将 arr1 左右两端的值赋给 arr2 左右两端的值
    arr2[left] = arr1[left];//将arr1左边的值 赋给 arr2左边的值
    arr2[right] = arr1[right];//将arr2右边的值 赋给 arr2右边的值
    //打印重新赋值后的arr2:
    printf("%s\n", arr2);
    //使用Sleep()函数进行优化:
    Sleep(1000);//休眠1000毫秒,即1秒,再执行后面的语句,需要头文件:<windows.h>
    //使用system()函数进行优化:
    system("cls");//清理屏幕
    //调整左右下标,以便下次循环改变下一对左右两端的值:
    left++; //调整左下标
    right--; //调整右下标
  }
  printf("%s\n", arr2);
  return 0;
}

实现图片:

image.png

最终代码和实现效果

最终代码:

#include <stdio.h>
#include <windows.h>
int main()
{
  //生成第一个字符串arr1:
  char arr1[] = "welcome to school!!!!!";
  //生成第二个字符串arr2:
  char arr2[] = "######################";
  //定义左右小标:left 和 right
  int left = 0;
  int right = strlen(arr1) - 1;
  //strlen(数组名称):求数组的长度,计算字符数组中\0前有多少个字符
  //数组长度 - 1 = 最右端下标 
  //使用while循环结合左右下标进行循环替换
  while (left <= right)
  //如果 left > right 说明数组中左右下标之间已经没有值了
  //有值就一直循环到没有值
  {
    //利用左右下标将 arr1 左右两端的值赋给 arr2 左右两端的值
    arr2[left] = arr1[left];//将arr1左边的值 赋给 arr2左边的值
    arr2[right] = arr1[right];//将arr2右边的值 赋给 arr2右边的值
    //打印重新赋值后的arr2:
    printf("%s\n", arr2);
    //使用Sleep()函数进行优化:
    Sleep(1000);//休眠1000毫秒,即1秒,再执行后面的语句,需要头文件:<windows.h>
    //使用system()函数进行优化:
    system("cls");//清理屏幕
    //调整左右下标,以便下次循环改变下一对左右两端的值:
    left++; //调整左下标
    right--; //调整右下标
  }
  printf("%s\n", arr2);
  return 0;
}


实现效果:

c224e14f7dbd4eeca9352dcf173a155a.png

相关文章
|
1月前
|
存储 搜索推荐 C语言
深入C语言指针,使代码更加灵活(二)
深入C语言指针,使代码更加灵活(二)
|
1月前
|
存储 程序员 编译器
深入C语言指针,使代码更加灵活(一)
深入C语言指针,使代码更加灵活(一)
|
1月前
|
C语言
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
深入C语言指针,使代码更加灵活(三)
|
1月前
|
C语言
C语言字符(串)函数
C语言字符(串)函数
|
2月前
|
安全 C语言
在C语言中,正确使用运算符能提升代码的可读性和效率
在C语言中,运算符的使用需要注意优先级、结合性、自增自减的形式、逻辑运算的短路特性、位运算的类型、条件运算的可读性、类型转换以及使用括号来明确运算顺序。掌握这些注意事项可以帮助编写出更安全和高效的代码。
49 4
|
1月前
|
存储 安全 编译器
深入C语言库:字符与字符串函数模拟实现
深入C语言库:字符与字符串函数模拟实现
|
2月前
|
存储 C语言
【C语言基础考研向】10 字符数组初始化及传递和scanf 读取字符串
本文介绍了C语言中字符数组的初始化方法及其在函数间传递的注意事项。字符数组初始化有两种方式:逐个字符赋值或整体初始化字符串。实际工作中常用后者,如`char c[10]=&quot;hello&quot;`。示例代码展示了如何初始化及传递字符数组,并解释了为何未正确添加结束符`\0`会导致乱码。此外,还讨论了`scanf`函数读取字符串时忽略空格和回车的特点。
|
1月前
|
C语言
C语言练习题代码
C语言练习题代码
|
1月前
|
C语言
C语言常见字符函数和字符串函数精讲
C语言常见字符函数和字符串函数精讲
|
2月前
|
存储 算法 C语言
数据结构基础详解(C语言):单链表_定义_初始化_插入_删除_查找_建立操作_纯c语言代码注释讲解
本文详细介绍了单链表的理论知识,涵盖单链表的定义、优点与缺点,并通过示例代码讲解了单链表的初始化、插入、删除、查找等核心操作。文中还具体分析了按位序插入、指定节点前后插入、按位序删除及按值查找等算法实现,并提供了尾插法和头插法建立单链表的方法,帮助读者深入理解单链表的基本原理与应用技巧。
505 6