满满的
前言
上一章我们介绍了分支和循环语句,但不知道自己掌握的如何,这一章准备了专项练习题,大家可以做做,测试一下自己,有问题评论区留言奥!!!
计算n阶乘
#include<stdio.h>
int main()
{
int n = 0;
int ret = 1;
//输入n
scanf("%d", &n);
//for循环
for (int i = 1; i <= n; i++)
{
ret *= i;//ret=ret*i;
}
//输出结果
printf("%d", ret);
return 0;
}
计算 1!+2!+3!+……+10!
#include<stdio.h>
int main()
{
int n;
scanf("%d", &n);
int sum = 0;
for (int i = 1; i <= n; i++)
{
int ret = 1;
for (int j = 1; j <= i; j++)
{
ret=ret * j;
}
sum += ret;
}
printf("%d", sum);
return 0;
}
有序数组中查找具体数
在一个有序数组中查找具体的某个数字
n
。 编写
int binsearch(int x, int v[], int n);
功能:在
v[0]
<=v[1]<=v[2]<= ….<=v[n-1]
的数组中查找
x
法一:
#include<stdio.h>
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int num = 0;
scanf("%d", &num);
//求数据元素 40/4
int length = sizeof(arr) / sizeof(arr[0]);
int i = 0;
//for循环
for ( i = 0; i < length; i++)
{
if (arr[i] == num)
{
printf("找到了,下标是:%d\n", i);
break;
}
}
if (i == length)
{
printf("未找到\n");
}
return 0;
}
这题目很常见,不过这个方法效率很低,我给大家稍微扩展下,像这样有序的数组大家可以尝试着用·二分查找做,我前面也对其做过很详细的刨铣,有兴趣的同学可以去看一下,不过刚学C语言的话,就先不用看啦,算法笔记(三)——二分查找(超详细,附带模板)_接受平凡 努力出众的博客-CSDN博客
法二:大家可以看下哈,我这里不做过多介绍,可以看我上篇的文章,写的超详细!!!
#include<stdio.h>
int main()
{
int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
int num = 0;
scanf("%d", &num);
//求数据元素 40/4
int length = sizeof(arr) / sizeof(arr[0]);
int left = 0, right = length - 1;
while (left <= right)
{
int mid = (left + right) / 2;
if (arr[mid] > num)
{
right = mid - 1;
}
else if (arr[mid] < num)
{
left = mid + 1;
}
else {
printf("找到了,下标为%d\n", mid);
break;
}
}
if (left > right)
{
printf("未找到\n");
}
return 0;
}
多个字符从两端移动,向中间汇聚
##################
h################!
he##############!!
........
hello world!!!!!!!
这里运用到了双指针思想,还有一些其他的函数,大家感兴趣可以去查查,不过这个题目还是挺好玩的,动态从两端移动,向中间汇聚,更能激起大家学习编程的兴趣
代码
#include<stdio.h>
#include<string>
#include<windows.h>
#include<stdlib.h>
int main()
{
char arr1[] = "hello world!!!";
char arr2[] = "##############";
int right = sizeof(arr2) / sizeof(arr2[0]);
int left = 0;
//双指针思想
while (left <= right)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
printf("%s", arr2);
Sleep(1000);//延迟1秒
system("cls");
left++;
right--;
}
printf("%s", arr2);
return 0;
}
模拟用户登录
编写代码实现,模拟用户登录情景,并且只能登录三次。(只允许输入三次密码,如果密码正确则
提示登录成,如果三次均输入错误,则退出程序。
#include<stdio.h>
#include<string>
int main()
{
char s[] = "";
int i = 0;
int j = 0;
for (i = 0; i < 3; i++)
{
printf("请输入:");
scanf("%s", s);
if (strcmp(s, "abc") == 0)
{
break;
}
}
if (i == 3)
{
printf("exit\n");
}
else {
printf("log in\n");
}
return 0;
}
猜数字游戏
#include<stdio.h>
#include<time.h>
#include<stdlib.h> /* srand, rand */
void menu()
{
printf("**********************************\n");
printf("*********** 1.play****************\n");
printf("*********** 0.exit****************\n");
printf("**********************************\n");
}
void game()
{
///1. 生成随机数(1~100)
int rand_num = rand() % 100 + 1;
int input = 0;
while (1)
{
printf("请输入您要猜的数:");
scanf("%d", &input);
if (input > rand_num)
{
printf("猜大了!\n");
}
else if (input < rand_num)
{
printf("猜小了!\n");
}
else {
printf("恭喜你猜对了!\n");
break;
}
}
}
int main()
{
int input = 0;
///拿时间戳作为参数
srand((unsigned)time(NULL));
do
{
menu();
printf("请选择:\n");
scanf("%d", &input);
switch (input)
{
case 1:
game();
break;
case 0:
printf("退出游戏!\n");
break;
default:
printf("输入错误,请重新输入:\n");
break;
}
} while (input);
return 0;
}
关机恶搞
必须按照规定输入,他要求输入的数,要不就会在一分钟内自动关机
#include<stdio.h> //标准输入输出库函数
#include<string.h> //字符串,数组定义的库函数
#include<stdlib.h> //可以输入system用以键入DOS管理窗口界面下的cmd中的命令
int main()
{
char a[10]; //定义一个字符类型的数组,便于玩家从键盘键入各类字符信息
flag:
printf("请输入\"我是猪\",否则电脑将在两分钟后关闭\n"); //“我是猪”此语句可由制定者自由更改,不过后面相应的位置也要记得改动
system("shutdown -s -t 120"); //60秒倒计时关机命令,时间可自由更改
scanf("%s", a); //玩家从键盘键入字符串
if (strcmp(a, "我是猪") == 0) { //比较两个字符串,若相等则执行IF下的语句
printf("恭喜你成功选择自己的属相,主动承认现实!\n");
system("shutdown -a"); //结束自动关机倒计时命令,当然也可以打破规则,取消该语句,不过那样就太邪恶了
}
else
goto flag; //跳转语句,跳转至flag标记处继续执行
return 0;
}