c++求:1+11+111+1111+11111+...的前5项的和 ;
3个回答
展开全部
一楼的肯定不行啊,要是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.
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+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楼的函数
#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楼的函数
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
从这个式子的规律来看,前5项必然是12345,所以不需要按部就班的进行数列求和,只需要从1到n列出数字即可.下面的应该是求前n项和最简单的一种了。
int sum(int n)
{
if(n==1)
return 1;
else
return 10*sum(n-1)+n;
}
int sum(int n)
{
if(n==1)
return 1;
else
return 10*sum(n-1)+n;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询