C语言-分支与循环语句练习2

1,计算n的阶乘

复制代码
#include<stdio.h>
#include<string.h>

//计算n的阶乘
int main() {
	int i = 1;
	int n = 0;
	int ret = 1;
	scanf("%d", &n);

	for ( i = 1; i <= n; i++)
	{
		ret = ret * i;
	}
	printf("%d\n", ret);
	return 0;
}

2,计算: 1! + 2! + 3! +......+10!

复制代码
#include<stdio.h>
#include<string.h>

//计算: 1! + 2! + 3! +......+10!
int main() {
	int i = 1;
	int n = 0;
	int ret = 1;
	int sum = 0;

	//法一
	//for ( n = 1; n <=10; n++)
	//{
	//	ret=1;//注意这个初始化
	//	for (i = 1; i <= n; i++)
	//	{
	//		ret = ret * i;
	//	}
	//	sum += ret;
	//}
	//printf("%d\n", sum);
	
	//法二
	for (n = 1; n <= 10; n++)
		{
			ret = ret * n;
			sum += ret;
		}
	printf("%d\n", sum);
			return 0;
}

3,在有一个有序数组中查找具体的某个数字

复制代码
#include<stdio.h>
#include<string.h>

////在有一个有序数组中查找具体的某个数字
// 
// 法一
// 
//int main() {
//	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
//	int k = 7;
//	int i = 0;
//	int sz = sizeof(arr) / sizeof(arr[0]);
//	for ( i = 0; i < sz; i++)
//	{
//		if (arr[i] == k) {
//			printf("找到了,下标是:%d\n", i);
//			break;
//		}
//	}
//	if (i==sz)
//	{
//		printf("找不到!\n");
//	}
//
//	return 0;
//}

//在有一个有序数组中查找具体的某个数字
//法二:折半查找(效率增高)
int main() {
	int arr[] = { 1,2,3,4,5,6,7,8,9,10 };
	int k = 7;
	int i = 0;
	int sz = sizeof(arr) / sizeof(arr[0]);

	int left = 0;
	int right = sz - 1;
	while (left <= right) {
		//int mid = (left + right) / 2;
		int mid = left+(right-left) / 2;


		if (arr[mid] < k) {
			left = mid + 1;
		}
		else if(arr[mid]>k) {
			right = mid - 1;
		}
		else
		{
			printf("找到了,下标是:%d\n", mid);
			break;
		}
	}
	if (left > right) {
				printf("找不到!\n");

	}

	return 0;
}

4,编写代码.演示多个字符从两端移动,向中间汇聚

复制代码
#include<stdio.h>
#include<string.h>
#include<windows.h>
#include<stdlib.h>
#include<time.h>
//编写代码.演示多个字符从两端移动,向中间汇聚
int main() {
	//welcome to bit!!!!
	//##################
	//w#################
	//we################
	//wel###############
	//.....
	//welcome to bit!!!!
	
	//char buf[] = "abc";
	//[a b c \0]
	//4

	char arr1[] = "welcome to bit!!!!";
	char arr2[] = "##################";

	int left = 0;
	int right = strlen(arr2) - 1;//int right = sizeof(arr1)/sizeof(arr1[0])-2;(注意:有个'\0')

	while (left<=right) {
		arr2[left] = arr1[left];
		arr2[right] = arr1[right];
		printf("%s\n", arr2);
		Sleep(1000);
		system("cls");//system是一个库函数,可以执行系统命令   清空屏幕
		left++;
		right--;


	}

	return 0;
}

5,编写代码实现,模拟用户登录情景,并且只能登录三次

复制代码
#include<stdio.h>
#include<string.h>
//编写代码实现,模拟用户登录情景,并且只能登录三次.
//(只允许输入三次密码,如果密码正确则提示登陆成功,如果三次均输入错误,则退出程序)
int main() {
	int i = 0;
	char password[20] = { 0 };
	//假设密码是字符串:abcdef
	for ( i = 0; i < 3; i++)
	{
		printf("请输入密码:>");
		scanf("%s", password);//数组名本身就是地址,不需要取地址符
		if (strcmp(password,"abcdef")==0)//比较两个字符串是否相等,不能使用==,而应该使用一个库函数:strcmp
		{
			printf("登录成功!\n"); 
			break;
		}
		else
		{
			printf("密码错误\n");
		}
	}
	if (i==3)
	{
		printf("三次密码输入错误,退出程序\n");
	}
	return 0;
}

6,猜数字游戏

复制代码
#include<stdio.h>
#include<string.h>
//猜数字游戏
//电脑产生一个随机数(1-100)
//猜数字
//猜大了
//猜小了
//直到猜对了,结束

//0-RAND_MAX(32767)
void game() {
	int guess = 0;
	//1.生成随机数
	int ret = rand()%100+1;//生成随机数的函数
	//printf("%d\n", ret);
	//2.猜数字
	while (1) {
		printf("请猜数字:>");
		scanf("%d", &guess);
		if (guess < ret)
			printf("猜小了\n");
		else if (guess>ret)
		{
			printf("猜大了\n");
		}
		else {
			printf("猜对了\n");
			break;
		}
	}
}
void menu() {
	printf("********************************\n");
	printf("************ 1.play ************\n");
	printf("************ 0.exit ************\n");
	printf("********************************\n");

}
int main() {
	int input = 0;
	srand((unsigned int)time(NULL));

	do {
		menu();
		printf("请选择:>");
		scanf("%d", &input);
		switch (input) {
		case 1:
			//printf("猜数字\n");
			game();//猜数字的整个逻辑
			break;
		case 0:
			printf("退出游戏\n");
			break;
		default:
			printf("选择错误,重新选择!\n");
			break;
		}
	} while (input);

	return 0;
}
相关推荐
枫叶丹4几秒前
【HarmonyOS 6.0】AVCodec Kit:OH_AVDataSource回调中传递用户自定义数据的深度解析
开发语言·华为·harmonyos
c++圈来了个新人2 分钟前
C++类和对象(中)
c语言·开发语言·数据结构·c++·考研·算法
xin_nai2 分钟前
LeetCode热题100 (Java)(1)哈希
算法·leetcode·哈希算法
格林威3 分钟前
面阵相机 vs 线阵相机:堡盟与海康相机选型差异全解析+python实战演示
开发语言·人工智能·python·数码相机·计算机视觉·视觉检测·工业相机
bucenggaibian5 分钟前
C语言如何直接控制硬件?指针、内存与寄存器
c语言·内存·指针·寄存器·硬件控制
2401_892070985 分钟前
红黑树(RBTree):原理 + 5 大性质 + 旋转 + 插入 + 删除 + 完整工程级代码逐行解析
c语言·数据结构·红黑树
Go away, devil6 分钟前
Java——IO
java·开发语言
oscar9997 分钟前
OpenCode Go :为开放编码模型准备的低价订阅方案
开发语言·后端·golang
王老师青少年编程7 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【删数问题】:删数问题2
c++·算法·贪心·csp·信奥赛
hanbr8 分钟前
Leetcode刷题总结(1)
算法·leetcode·职场和发展