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;
}
相关推荐
AIpanda8881 小时前
什么是AI销冠系统和AI提效软件系统?主要区别和应用场景是什么?
算法
懒惰成性的1 小时前
Java方法的使用
java·开发语言
Once_day1 小时前
GCC编译(3)常见编译选项
c语言·c++·编译和链接
程序员酥皮蛋2 小时前
hot 100 第三十三 33.排序链表
数据结构·算法·链表
蚊子码农2 小时前
算法题解记录-2452距离字典两次编辑以内的单词
开发语言·算法·c#
wangbing11252 小时前
Java构造函数不能加void
java·开发语言
Never_Satisfied2 小时前
在JavaScript / HTML中,数组查找第一个符合要求元素
开发语言·javascript·html
重生之后端学习2 小时前
207. 课程表
java·数据结构·算法·职场和发展·深度优先
爱编码的小八嘎2 小时前
第3章 Windows运行机理-3.1 内核分析(3)
c语言