c++函数1^k+2^k+3^k+4^k+ n^k
c++编写函数1^k+2^k+3^k+4^k+n^k————就是:1的k次方+2的k次方+3的k次方+4的k次方+……n的k次方的和,用c++函数编写……谢谢...
c++编写函数1^k+2^k+3^k+4^k+ n^k————就是:1的k次方+2的k次方+3的k次方+4的k次方+……n的k次方 的和,用c++函数编写……谢谢
展开
6个回答
展开全部
有一个很关键的数学函数:pow(double n,double k),用来计算n的k次方。比如pow(2,3),则函数返回8(即2^3 = 8),该函数包含在头文件<math.h>中。
C++代码如下:
#include<iostream.h>
#include<math.h>
void main()
{
long n,k;
long sum = 0;
cout<<"输入n值:"<<endl;
cin>>n;
cout<<"输入k值:"<<endl;
cin>>k;
for(int i = 1; i <= n; i++)
sum += pow(i,k);
cout<<sum;;
}
C++代码如下:
#include<iostream.h>
#include<math.h>
void main()
{
long n,k;
long sum = 0;
cout<<"输入n值:"<<endl;
cin>>n;
cout<<"输入k值:"<<endl;
cin>>k;
for(int i = 1; i <= n; i++)
sum += pow(i,k);
cout<<sum;;
}
本回答被提问者和网友采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <stdio.h>
int power(int n, int k)
{
if (n < 1 || k < 1) return 1;
int i = k; int j = 1;
do {
j *= n;
i --;
}while(i);
return j;
}
int main(void)
{
int n = 0; int k = 0; int sum = 0;
printf("请输入n, k的值");
scanf("%d %d", &n, &k);
for (i = 1; i <= n; i ++)
sum += power(i, k);
printf("求和=%d", sum);
return 0;
}
int power(int n, int k)
{
if (n < 1 || k < 1) return 1;
int i = k; int j = 1;
do {
j *= n;
i --;
}while(i);
return j;
}
int main(void)
{
int n = 0; int k = 0; int sum = 0;
printf("请输入n, k的值");
scanf("%d %d", &n, &k);
for (i = 1; i <= n; i ++)
sum += power(i, k);
printf("求和=%d", sum);
return 0;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <iostream>
#include <cmath>
using namespace std;
int sumnk(int sum,int n,int k);
int main()
{
int sum(0),int n(0),int k(0);
cin >> n >> k;
cout << sumnk(sum,n,k) << endl;
return 0;
}
int sumnk(int sum,int n,int k)
{
if(n == 1)
{
sum += 1;
return sum;
}
sum += pow(float(n),k);
--n;
sumnk(sum,n,k);
}
#include <cmath>
using namespace std;
int sumnk(int sum,int n,int k);
int main()
{
int sum(0),int n(0),int k(0);
cin >> n >> k;
cout << sumnk(sum,n,k) << endl;
return 0;
}
int sumnk(int sum,int n,int k)
{
if(n == 1)
{
sum += 1;
return sum;
}
sum += pow(float(n),k);
--n;
sumnk(sum,n,k);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
#include <cmath>//或者是<math.h>
using std::pow;
long powk(int n)
{
long sum =0;
for(int i=1;i<=n;i++)
{
sum+= pow(i,k)
}
return sum;
}
using std::pow;
long powk(int n)
{
long sum =0;
for(int i=1;i<=n;i++)
{
sum+= pow(i,k)
}
return sum;
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
有数据范围吗?这个很容易溢出啊。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询