1.计算n的阶乘

int main()
{
	int ret = 1;
	int i = 0;
	int n = 0;
	scanf("%d", &n);       //注意取地址符号&别忘记
	for (i = 1; i <= n; i++)
	{
		ret = ret * i;

	}
	printf("ret=%d\n", ret);
	return 0;
}

效果如下所示:

2.C语言学习--分支与循环例题分析_二分查找法

2.计算1!+2!+...+10!

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

2.C语言学习--分支与循环例题分析_分支与循环_02

3.在一个有序数组中查找一个固定的值

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 (k == arr[i])
		{
			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 sz = sizeof(arr) / sizeof(arr[0]);    //计算元素个数
	int k = 7;       //设置需要查找的数
	int left = 0;  //左下标
	int right = sz - 1;    //右下标
	while (left<=right)  //注意要求条件
	{
		int mid = (left + right) / 2;
		if (arr[mid] > k)
		{
			right = mid - 1;
		}
		else if (arr[mid] < k)
		{
			left = mid + 1;
		}
		else
		{
			printf("找到了,下标是:%d\n", mid);
			break;//找到后跳出
		}
	}
	if (left > right)   //不存在
		printf("找不到。");
	return 0;
}

注意需要划分两种情况,一种是当”left<=right“时,另一种时”left > right“。而只有第一种情况才是进行循环的条件,第二种可以判断不存在。

2.C语言学习--分支与循环例题分析_i++_03

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

int main()
{
	char arr1[] = "welcome to China!!!!!!";
	char arr2[] = "######################";
	int left = 0;
	int right = strlen(arr1) - 1;
	while (left <= right)
	{
		arr2[left] = arr1[left];
		arr2[right] = arr1[right];
		printf("%s\n", arr2);
		Sleep(500);//休息0.5秒
		system("cls");//执行系统命令的一个函数cls--清空屏幕,若不清空屏幕,则会打印很多遍
		left++;//这里是实现从两端移动向中间汇聚,若要从左到右展开,则注释掉right--
		right--;
	}
	printf("%s\n", arr2);//这一步骤是让结果在完整的输出一遍
	return 0;
}

2.C语言学习--分支与循环例题分析_二分查找法_04

这里需要注意一点:”left++;right--;“这里是实现从两端移动向中间汇聚,若要从左到右展开,则注释掉”right--;”


5.编写代码,模拟用户登陆场景,并且只能登录三次。(只允许输入三次密码,若密码正确则登陆成功,若三次均错误,则退出程序)

int main()
{
	int i = 0;
	char password[20] = { 0 };
	for (i = 0; i < 3; i++)
	{
		printf("请输入密码:>");
		scanf("%s", password);
		//stringcompare--库函数,用于比较两个字符串是否相等
		//strcmp(a,b)若a>b,则返回一个大于零的数字;若a<b,则返回一个小于零的数字。
		if (strcmp(password, "123456") == 0)
		{
			printf("登陆成功!\n");
			break;
		}
		else
		{
			printf("密码错误!!!\n");
		}
	}
	if (i == 3)
		printf("三次密码均错误,退出程序!\n");
	return 0;

}

2.C语言学习--分支与循环例题分析_i++_05

2.C语言学习--分支与循环例题分析_i++_06

看了这些例题大家应该对分支与循环的题目有一定的理解了吧,加油!!!

2.C语言学习--分支与循环例题分析_分支与循环_07