林惜城


私信TA

用户名:reminder

访问量:27442

签 名:

等  级
排  名 94
经  验 8468
参赛次数 0
文章发表 95
年  龄 0
在职情况 学生
学  校 西安电子科技大学
专  业

  自我简介:

哈姆

TA的其他文章

1075: 台球碰撞
浏览:1264
1076: 内部收益率
浏览:443
1083: Hello, world!
浏览:245

解题思路:

暴力的方法是写一个阶乘函数,从1到30调用函数,但是非常耗时。根据(n+1)! = n! * (n+1),可以定义一个i从1递增到30,定义一个变量保存更新后的阶乘,每更新一次就加到总和上,然后i++,这样就大大减轻了时间消耗。


注意事项:

阶乘和总和都要用double表示。


参考代码:

// 题目 1064: 二级C语言-阶乘数列
#include<iostream>

using namespace std;

int main() {
	int num = 30;    // n的阶乘
	int i = 1;       // (n+1)! = n! * (n+1),此时i=n+1
	double fact = 1; // 阶乘
	double sum = 0;  // 结果
	while (num--) {
		fact *= i;
		sum += fact;
		i++;
	}
	printf("%.2e\n", sum); // 科学计数法(保留2位小数)
	return 0;
}


 

0.0分

4 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区