多个字符从两端移动,向中间汇聚

hello呀,菜鸡哥又来咯,你是不是很想念啊!别急,马上开讲今天的内容!

多个字符从两端移动,向中间汇聚_第1张图片

就是上图的这个效果咯,你知道怎么弄吗?

*逐渐变成了其他的字母,是不是应该有两个字符类型的数组呢?

char arr1[] = "do you love me?";
char arr2[] = "***************";

从两边一一对应的交换到中间来,只要解决两边的位置,那我们就可以进行交换了。

数组的下标是从零开始的:left = 0

那么最后一个可以怎么表示呢?我们可以用到:

strlen,它的作用是计算字符串的长度,但不包括“\0”在内。  right = strlen(arr1) - 1;(因为下标是从0开始的,所以要-1).

现在我们就可以进行交换了:

arr2[left] = arr1[left];//交换
arr2[right] = arr1[right];
left++;//左边加加,向中
right--;//右边减减,向中

大功告成咯!看看整体代码:

#define _CRT_SECURE_NO_WARNINGS 1
#include 
#include 

int main()
{
	char arr1[] = "do you love me?";
	char arr2[] = "***************";
	int left = 0;
	int right = strlen(arr1) - 1;
	//int sz = sizeof(arr1)/sizeof(arr1[0]);
	//int right = sz - 2;

	while (left <= right)
	{
		arr2[left] = arr1[left];
		arr2[right] = arr1[right];

		printf("%s\n", arr2);
		Sleep(1000);//睡眠1000毫秒,一个库函数,用于使程序暂停执行一段指定的时间
		system("cls");//system是库函数,执行系统指令,cls是清理控制台屏幕信息

		left++;
		right--;
	}
	printf("%s\n", arr2);
	return 0;
}

sleep是为了好观察它是一步一步怎样变的,其中的system(“cls”),展现的效果是:

 如图所示,正在交换中

好了,那么我们今天的相遇时间就到此了,很快吧。对的呢,时间过的可快了,所以我们要抓紧时间咯!

你可能感兴趣的:(c语言)