1.完成猜数字游戏。
#include<stdio.h>
#include<time.h>
int main()
{
int a;
int num;
//设置随机种子
srand((unsigned int)time(0));
//设置随机数
a=rand() % 100 + 1;
scanf("%d", &num);
while (num != a)
{
if (num < a)
{
printf("数字低了");
}
if (num > a)
{
printf("数字高了");
}
scanf("%d", &num);
}
if (num == a)
{
printf("回答正确");
}
}
注意:随机数种子的设置是很重要的,必不可少的。如果缺少随机数种子,那么多次执行程序后,就会发现产生的随机数与前几次产生的一样,这样就达不到随机的目的。
2.写代码可以在整型有序数组中查找想要的数字,找到了返回下标(折半查找)
#include<stdio.h>
int main()
{
int a[] = { 4,8,9,10,12,15,18,19,20 };
int left = 0;
int num;
int right = sizeof(a) / sizeof(a[0]) - 1;
int mid = 0;
printf("请输入你想要查找的数:\n");
scanf("%d",&num);
while (left <= right)
{
mid=(right+left)/2;
if (num < a[mid])
{
right = mid - 1;
}
else if (num > a[mid])
{
left = mid + 1;
}
else
break;
}
if(left<=right)
printf("%d\n", mid);
}
代码sizeof(arr) / sizeof(arr[0])
代表的意思是求数组arr的长度,也就是元素个数。其中sizeof(arr)
意思是:求取数组arr所占的总的字节数,也就是所占的内存空间的大小。sizeof(arr[0])
意思是:求一个数组元素所占的字节数。所以它们相除就得到数组的长度。
使用折半查找时,要首先设置三个参数:left、right、mid
。分别代表数组的最左边、最右边以及中间。我们输入要查找的数num
后,首先用if
语句判定num
的取值范围,如果num
在mid
的左边,则left
不变,将mid-1
的值赋给right
,如果是在mid
的右边,则right
不变,将mid+1
的值赋给left
,直到left<=right
。
注意:使用折半查找必须保证数组是有序的。
3.编写代码模拟三次密码输入的场景。最多能输入三次密码,密码正确,提示“登录成功”,密码错误,可以重新输入,最多输入三次。三次均错,则提示退出程序。
#include<stdio.h>
int main()
{
int password = 123456;
int key, count=0;
printf("请输入密码:");
scanf("%d", &key);
while (key!=password && count<3)
{
printf("密码错误,请重新输入密码:");
scanf("%d", &key);
count++;
}
if (key == password)
{
printf("密码正确");
}
return 0;
}
4.编写一个程序,可以一直接收键盘字符,如果是小写字符就输出对应的大写字符,如果接收的是大写字符,就输出对应的小写字符,如果是数字不输出。
#include<stdio.h>
int main()
{
char a;
while (1)
{
a = getchar();
if (a >= 'A'&&a <= 'Z')
{
printf("%c\n", a + 32);
}
if (a >= 'a'&&a <= 'z')
{
printf("%c\n", a - 32);
}
}
return 0;
}