标题:自然数的和
只看楼主
kisseshacker
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-12-28
结帖率:100%
已结贴  问题点数:20 回复次数:8 
自然数的和
1+2+3+...+100
1+3+5...+99
2+4+6+...+100
2+22+222+...
搜索更多相关主题的帖子: 自然数 
2018-01-04 10:45
吹水佬
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:432
帖 子:10064
专家分:41463
注 册:2014-5-20
得分:0 
有什么问题?
2018-01-04 11:06
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:5 
等差数列求和 = (a1+an)*(an-a1+差)/差/2
1+2+3+...+100 = (1+100)*(100-1+1)/1/2 = 5050
1+3+5...+99   = (1+99)*(99-1+2)/2/2 = 2500
2+4+6+...+100 = (2+100)*(100-2+2)/2/2 = 2550

等比数列求和
2+22+222+... = 我靠,白痴也知道这是无穷大?
假设是求 2 + 22 + 222 + ... + 222…(共10个2)
 = (2/9) * ( 9 + 99 + 999 + ... + 999…(共10个9) )
 = (2/9) * ( 10+100+1000+...+1000…(共10个0) - 10 )
 其中 10+100+1000+... 是个等比数列,公式 a1 * (q^n-1)/(q-1),即 10*(10^10-1)/(10-1)=11111111110
 = (2/9) * ( 11111111110 - 10 )
 = 2469135800
2018-01-04 11:18
wp231957
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:神界
等 级:版主
威 望:422
帖 子:13681
专家分:53296
注 册:2012-10-18
得分:0 
回复 3楼 rjsp
你说这种题目 到底是老老实实的累加编程呢  还是套用公式编程呢

DO IT YOURSELF !
2018-01-04 11:21
kisseshacker
Rank: 1
等 级:新手上路
帖 子:9
专家分:0
注 册:2017-12-28
得分:0 
回复 4楼 wp231957
公式编程啊
2018-01-04 11:40
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:507
帖 子:8890
专家分:53117
注 册:2011-1-18
得分:0 
回复 4楼 wp231957
这就看实际需求了
2018-01-04 12:00
白山茶
Rank: 1
等 级:新手上路
帖 子:5
专家分:5
注 册:2018-1-3
得分:5 
累加感觉还可以 比如Description


Sn=2+22+222+2222+22222+22...2222(最后一项n个2)

Input


n

Output


Sn

Sample Input
5

Sample Output
24690



代码:
#include<stdio.h>
#include<math.h>
int main(   )
{  
     int n,Sn,a,i;
     scanf(  "%d",&n  );
     i=1;
    a=1;
   Sn=0;
     while(  i<=n  )
   {  Sn=Sn+2*a;
a=a*10;
 i++;
a++; }
printf(  "%d",Sn  );
return 0;
  }
2018-01-04 13:19
wp231957
Rank: 16Rank: 16Rank: 16Rank: 16
来 自:神界
等 级:版主
威 望:422
帖 子:13681
专家分:53296
注 册:2012-10-18
得分:10 
以下是引用白山茶在2018-1-4 13:19:43的发言:

累加感觉还可以 比如Description


Sn=2+22+222+2222+22222+22...2222(最后一项n个2)

Input


n

Output


Sn

Sample Input
5

Sample Output
24690



代码:
#include<stdio.h>
#include<math.h>
int main(   )
{  
     int n,Sn,a,i;
     scanf(  "%d",&n  );
     i=1;
    a=1;
   Sn=0;
     while(  i<=n  )
   {  Sn=Sn+2*a;
a=a*10;
 i++;
a++; }
printf(  "%d",Sn  );
return 0;
  }

扯远了吧  N个2啊  往少了说 100个2 你这代码能行吗

DO IT YOURSELF !
2018-01-04 14:37
GBH1
Rank: 7Rank: 7Rank: 7
等 级:黑侠
威 望:5
帖 子:112
专家分:510
注 册:2017-6-13
得分:0 
像这种2,22,222,2222,22222。。。。
个人觉得用位运算比较合适
2018-01-04 15:42



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-483954-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 1.094269 second(s), 8 queries.
Copyright©2004-2025, BCCN.NET, All Rights Reserved