1、编写代码实现模拟用户登录情景,并且只能登录四次,如果四次均输入错误,则退出程序。
#include<stdio.h>
#include<string.h>
int main()
{
int i = 1;
char password[] = { 0 };
for (i = 0; i < 4; i++)
{
printf("请输入密码:\n");
scanf("%s", password);
if (strcmp(password,"888888")==0)
//"=="不能用来判断两个字符串是否相等,要使用一个库函数:strcmp
//strcmp相等则返回0
{
printf("密码正确,登录成功\n");
break;//注意此处
}
else
{
printf("密码错误,请重新输入\n");
}
}
if (i == 4)
{
printf("四次密码均错误,将退出程序\n");
}
return 0;
}
2、演示多个字符从两端移动向中间汇聚。
#include<stdio.h>
#include<string.h>
#include<Windows.h>
#include<stdlib.h>
int main()
{
char arr1[] = "The world is splendid and grand. Welcome home!!!";
char arr2[] = "************************************************";
int left = 0;
//int sz = (sizeof(arr1)/sizeof(arr1[0]))-2;//减二是因为字符串中最后为"\0",再加上下标比位数小一
int right = strlen(arr1) - 1;//strlen函数计算字符串长度,且不考虑最后的"\0"
while (left <= right)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s\n", arr2);
//Sleep(500);//休息半秒(1)
//system("cls");//执行系统命令的一个函数:cls,用来清空屏幕(2)
left++;
right--;
}
//printf("%s\n\n", arr2);(3)
return 0;
}
运行结果:
读者有兴趣的话,可以取消掉(1)(2)(3)句的注释,效果也是很不错的。
3、在一个有序数组中查找具体的某个数字n,用二分查找算法或叫折半查找算法实现。
#include<stdio.h>
int main()
{
int k = 0;
char arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int left = 0;//左下标
int sz = sizeof(arr) / sizeof(arr[0]);//计算数组元素个数,为计算右下标做准备
int right = sz - 1;//计算右下标
printf("请输入你打算查找的数字:\n");
scanf("%d", &k);
while (left <= right)
{
int mid = (left + right) / 2;
if (arr[mid] < k)
{
left = mid + 1;
}
else if (arr[mid] > k)
{
right = mid - 1;
}
else
{
printf("找到了,在数组的第%d个位置上", mid);
break;
}
}//while循环体,关键是通过下标来定位数组中元素位置,再和k进行比较
//获取k在该有序数组中更精确的定位,根据大小关系,不断更改下标大小,精确k的区间
if (left > right)
printf("没找到\n");
return 0;
}
运行结果:
好了,今天就先这样子,我们明天再见!