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;
}
相关推荐
码农-阿杰1 分钟前
Java 线程等待唤醒机制深度解析:synchronized、ReentrantLock、LockSupport 底层实现对比
java·开发语言·c++
赤水无泪2 分钟前
Qt 全模块汇总列表
开发语言·qt
小虎牙0076 分钟前
面试被问复杂度总懵?这篇指南帮你彻底搞清
算法
yong99909 分钟前
MATLAB仿真计算电磁波回波信号的技术路径与实现指南
开发语言·matlab
不是光头 强16 分钟前
Spring Boot 多线程场景下 i18n 国际化失效问题排查与解决
java·开发语言·springboot
jieyucx16 分钟前
Go 语言核心关键字:defer 深度解析与实战避坑
开发语言·后端·golang·defer
星恒随风23 分钟前
四天学完前端基础三件套(JavaScript篇)
开发语言·前端·javascript·笔记
12.=0.28 分钟前
【stm32_9.2】FreeRTOS的任务管理:任务策略,调度器启用,任务创建、删除、挂起、恢复
c语言·stm32·单片机·嵌入式硬件
杜子不疼.1 小时前
【 C++ AI 大模型接入 SDK】 - 日志模块
开发语言·javascript·c++
knight_9___1 小时前
大模型project面试4
人工智能·python·深度学习·算法·面试·agent