之前学习了数组,现在我们就来实践一下吧!!!!
练习1:多个字符从两端移动,向中间汇聚
代码演示:多个字符从两杜端移动,向中间汇聚
#include <stdio.h>
#include <string.h>
#include <windows.h>
int main()
{
char arr1[] = "#################";
char arr2[] = "Me and my brother";
int left = 0;
int right = strlen(arr2)-1;
while (left <= right)
{
Sleep(1000);//Sleep函数的作用:睡眠1000毫秒
system("cls");//system--库函数(执行) cls---清空屏幕
arr1[left] = arr2[left];
arr1[right] = arr2[right];
printf("%s\n", arr1);
left++;
right--;
}
return 0;
}
练习2:⼆分查找
在⼀个升序的数组中查找指定的数字n,很容易想到的⽅法就是遍历数组,但是这种⽅法效率⽐较低。 ⽐如我买了⼀双鞋,你好奇问我多少钱,我说不超过300元。你还是好奇,你想知道到底多少,我就让 你猜,你会怎么猜?你会1,2,3,4...这样猜吗?显然很慢;⼀般你都会猜中间数字,⽐如:150,然 后看⼤了还是⼩了,这就是⼆分查找,也叫折半查找。
#include<stdio.h>
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9 };
int left = 0;
int right = sizeof(arr) - sizeof(arr[0])-1;
int mid = 0;//记录数组的中间元素的位置
int find = 0;
int key = 0;
printf("输入你想要找的数\n");
scanf("%d", &key);
while (left <= right)
{
mid = (left + right) / 2;
if (arr[mid] < key)
{
left = mid + 1;
}
else if (arr[mid] > key)
{
right = mid - 1;
}
else
{
find = 1;
break;
}
}
if (find == 0)
{
printf("不好意思没有找到%d\n", key);
}
else
{
printf("找到了,下标是%d\n", mid);
}
return 0;
}