求阶乘
一、求n的阶乘
#include<stdio.h>
#include<stdlib.h>
int main()
{
int n = 0;
printf("请输入需要求的数字:")
scanf("%d",&n);
//这里的result只能为1,不能为0
int result = 1;
for(int i = 1;i <= n;i++)
{
result = result * i;
}
printf("%d\n",result);
system("pause");
return 0;
}
二、求1!+2!+3!..+10!
此处需要两重循环
代码如下(示例):
#include<stdio.h>
#include<stdlib.h>
int main()
{
int n = 10;
int sum = 0;//用这个变量来保存阶乘求和的结果
//第一重循环用于控制求和
for(int cur = 1;cur <= n;cur++)
{
int factor = 1;//用于保存当前cur!的结果
//第二重循环用于计算当前数字的阶乘
for(int i = 1;i <= cur;i++)
{
factor = factor * i;
}
//循环结束的时候factor里的值就是cur阶乘的结果
sum = sum + factor;
}
printf("%d\n",sum);
system("pause");
return 0;
)
**小结:**这里主要用到了两重循环,所以看起来会比较复杂,不太容易看懂,代码的可读性太差,因此对代码可以优化。
代码如下(示例):
#include<stdio.h>
#include<stdlib.h>
//封装
int factor(int n)
{
int result = 1;
for(int i = 1;i <= n;i++)
{
result = result * i;
}
return result;
}
int main()
{
int n = 10;
int sum = 0;
for(int i = 0;i <= 10;i++)
{
sum = sum + factor(i);
}
printf("sum = %d\n",sum);
system("pause");
return 0;
}
三、多个字符从两端移动向中间靠近
例如:本来有一个字符串"hello word"
打印的时候这样来打印
先打印"h########d"
再打印"he######rd"
再打印"hel####ord"
#include<stdio.h>
#include<stdlib.h>
#include<string.h>
#include<windows.h>
int main()
{
//先创建字符串
char str1[] = "hello word";
char str2[] = "##########";
//此处使用两个变量,来控制两个方向各自打印多少字符
int left = 0;
int right = strlen(str1)-1;
printf("%s\n",str2);
//两侧向中间汇聚,其实最后就会让left和right重合
while(left <= right)
{
sleep(500);
system("cls");
//打印之前,先修改str2的内容
str2[left] = str1[left];
str2[right] = str1[right];
printf("%s\n",str2);
left++;
right--;
}
system("pause");
return 0;
}