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

2025-03-07 16:40:06
推荐回答(3个)
回答1:

一楼的肯定不行啊,要是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.

回答2:

//1+11+111+1111+11111+...的和,VC中测试通过
#include
using namespace std;
int sum(int n) ;
void main()
{
cout<}
int sum(int n)
{
if(n==1)
return 1;
else
return 10*sum(n-1)+n;
}

谢谢1楼的函数

回答3:

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

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