前言
通过上文的关于分支循环语句的讲解答,本文将通过一些例题给大家更直观的学习感受
一、计算n的阶乘
问题分析
首先,我们先要明白什么是阶乘,阶乘指从1乘以2乘以3乘以4一直乘到所要求的数。在表达阶乘时,就使用“!”来表示。如h阶乘,就表示为h!,如5的阶乘就表示为5!= 1x2x3x4x5,我们可以知道,n!即表示为需要生成n个数字,n! = 1~n的累积相乘。思路有了,下面我们通过代码实现。
代码实现
#include"stdio.h"
int main()
{
int n;
scanf("%d", &n);
int mut = 1;
for (int i = 1; i <= n; i++)//生成1~n的数
{
mut *= i;
}
printf("%d", mut);
return 0;
}
这里需要有个小tip,就是以上的情况是在考虑不溢出的情况,应为int可表述的最大值如下
define INT_MAX 2147483647//整形可以表示的最大值
二、计算 1!+2!+3!+……+10!
问题分析
看到这个问题,结合上面第一题对于单个n阶乘的分析后,不是觉得信手拈来?我们只需要另外在设置一个变量,将每次所相乘的阶乘进行相加,最后将得出的总和进行相加输出就好
代码实现
#include"stdio.h"
int main()
{
int n;
scanf("%d", &n);
int mut = 1;
int sum = 0;
for (int i = 1; i <= n; i++)//生成1~n的数
{
mut *= i;
sum += mut;//将每次的阶乘进行相加
}
printf("%d", sum);
return 0;
}
三、编写代码,演示多个字符从两端移动,向中间汇聚
需求演示
hello world
************
h**********d
he********ld
......
hello world
问题分析
首先,我们可以定义两个字符串的数组
分别是“hello world”和“************”
其次我们的替换原则就是左边替换左边, 右边替换右边
如图所示,接着我们将第一个字符串的最左边的第一个字符定义为left,最右边的第一个字符定义为right,left向右边走,right向左边走,当left<=right的时候,即可实现全部替换。如下图所示
代码实现
int main()
{
char arr1[] = "hello world";
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);
left++;
right--;
}
return 0;
}
不仅如此,我们还可以结合windows的指令对我们的代码进行优化,还有可以使用我们学过的for循环,这样可以使我们的代码更加紧凑,美观
int main()
{
char arr1[] = "hello world";
char arr2[] = "***********";
int left = 0;
int right = 0;
for(left = 0, right = strlen(arr1) - 1; left <= right; left++, right--)
{
arr2[left] = arr1[left];
arr2[right] = arr1[right];
Sleep(1000);
system("cls");
printf("%s\n", arr2);
}
return 0;
}
在使用windows的相关命令的时候别忘了导入库头哦,#include"windows.h"
总结
以上就是对于分支和循环的相关经典例题的一些讲解了,有哪里写的不好的可以在评论区指出来哦,谢谢