c++求:1+11+111+1111+11111+...的前5项的和 ;

如题所述

一楼的肯定不行啊,要是2+22+222+2222+22222+~怎么办呢!
main()
{int i,n,m,sum=0;
scanf("%d%d",&m,&n);
if n<=9&&n>=1
{for(i=1;i++;i<=m)
{sum=sum+n;
n=n*10+n;}
printf("%d",sum);}
else
printf("error");
}
m是你要求多少项的和,你的问题是5项,n是你求的那个数字,你的问题是1,我上面说的是2,你也可以求3,4,5,等等,但是最大为9.
温馨提示:答案为网友推荐,仅供参考
第1个回答  2008-05-09
//1+11+111+1111+11111+...的和,VC中测试通过
#include <iostream>
using namespace std;
int sum(int n) ;
void main()
{
cout<<sum(11)<<endl;
}
int sum(int n)
{
if(n==1)
return 1;
else
return 10*sum(n-1)+n;
}

谢谢1楼的函数
第2个回答  2008-05-04
从这个式子的规律来看,前5项必然是12345,所以不需要按部就班的进行数列求和,只需要从1到n列出数字即可.下面的应该是求前n项和最简单的一种了。

int sum(int n)
{
if(n==1)
return 1;
else
return 10*sum(n-1)+n;
}