1、 写一个代码,在arr数组(有序的)中找到 6
2、 写一个代码,在arr数组(有序的)中找到 6 (二分法查找)
3、 编写代码,演示多个字符从两端移动,向中间汇聚
4、编写代码,模拟用户登录情景,并且只能登录三次(只允许输入三次密码,如果密码正确则提示登录成功,如果三次均错误,则退出程序)
1、 写一个代码,在arr数组(有序的)中找到6
#include <stdio.h>
int main()
{
int arr[] = {1,2,3,4,5,6,7,8,9,10};
int k = 6;
int i =0;
int z = sizeof(arr)/sizeof(arr[0]);
for(i=0;i<z;i++)
{
if(k == arr[i])
{
printf(“找到了,下标是:%d\n”,i);
break;
}
}
if(i == z)
printf(“找不到了\n”);
return 0;
}
2、 写一个代码,在arr数组(有序的)中找到6 (二分法查找)
#include <stdio.h>
int main()
{
int arr[] = {1,2,3,4,5,6,7,8,9,10};
int k = 6;
int z = sizeof(arr)/sizeof(arr[0]); //计算元素个数
int left = 0; // 左下标
int right = z-1; // 右下标
while(left<=right)
{
int mid = (left+right)/2; //mid中间值
if(arr[mid] > k)
{
right = mid-1; //右下标
}
else if(arr[mid] < k)
{
left = mid+1; // 左下标
}
else
{
printf(“找到了,下标是:%d\n”,mid);
break;
}
}
if(left>right)
{
printf(“找不到\n”);
}
return 0;
}
3、 编写代码,演示多个字符从两端移动,向中间汇聚
#include <string.h>
#include <windows.h>
#include <stdlib.h>
int main()
{
// welcome to school!!!
//####################
//w##################!
//we################!!
//wel##############!!!
//…
//welcome to school!!!
char arr1[] = "welcome to school!!!!!!";
char arr2[] = "#######################";
int left = 0;
int right = strlen(arr1)-1; //strlen求字符串长度 //strlen未定义 #include <string.h>
while(left<=right)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s\n",arr2);
// 休息一秒
Sleep(1000); // 用Sleep #include <windows.h>
system("cls"); //执行系统命令的一个函数 cls 清空屏幕 #include <stdlib.h>
left++;
right--;
}
printf("%s\n",arr2);
return 0;
}
4、编写代码,模拟用户登录情景,并且只能登录三次(只允许输入三次密码,如果密码正确则提示登录成功,如果三次均错误,则退出程序)
#include <stdio.h>
#include <string.h>
int main()
{
int i = 0;
char password[20] = {0};
for(i=0;i<3;i++)
{
printf(“请输入密码\n”,i);
scanf("%s",password);
if(strcmp(password,“123456”) == 0) // == 不能用来比较两个字符串相等,应该使用一个库函数-strcmp
// strcmp #include <string.h>
{
printf(“登录成功\n”);
break;
}
else
{
printf(“密码错误\n”);
}
}
if(i == 3)
{
printf(“三次密码均错误,退出程序”);
}
return 0;
}