小菜


私信TA

用户名:1986489560

访问量:1241

签 名:

要向阳而生

等  级
排  名 30208
经  验 504
参赛次数 0
文章发表 3
年  龄 20
在职情况 学生
学  校 山西科技学院
专  业

  自我简介:

解题思路:

题目所求是先阶乘然后求和;

这个题有两个步骤,先算各项阶乘所得,再将所得数值相加得到Sn。

首先是阶乘,其实就是累乘的一个过程,核心代码为s=s*i;

其次是各项树相加,是累加的过程,核心代码为Sn=Sn+s;

最后输出Sn的值,即为所求值;

注意事项:1.不管是各项数s还是最后求的Sn,int 是不够用的,如果结果偏大,会有溢出的现象,所求值不完整不准确,所以要用long long来防止数组越界;

2.在这里是采用的dowhile语句,一般情况下我们不使用这个语句,但是累计问题,明显采用dowhile语句更方便一点,解题过程一目了然,一点都不复杂;
3.大家有什么建议或者不懂的 可以评论和留言,希望给大家带来帮助;
参考代码:

#include<iostream>

using namespace std;

int main()

{

int n;

cin>>n;

int i=1;

long long Sn=0;

long long s=1;

do

{

s=s*i;//累乘过程,求各项数;

i++;//i的自增来使实现累乘和累加过程;

Sn=Sn+s;//累加,继承求和;

}while(i<=n);


cout<<Sn<<endl;

return 0;

}


 

0.0分

0 人评分

  评论区

  • «
  • »