| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1884 人关注过本帖
标题:关于自然数的高次幂的问题
只看楼主 加入收藏
msshadow
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2007-5-30
收藏
 问题点数:0 回复次数:11 
关于自然数的高次幂的问题
请教一个关于高次幂的问题:
我们要求计算1 + 2 + 3 + … + n, 而n很大(例如1000000)时,大概我们会用求和公式 S1(n) = 1 + 2 + 3 +… + n = n (n+1)/2 计算,而不会直接去累加。
对于 1^2 + 2^2 + 3^2 + … + n^2 , 我们有求和公式
S2 (n) = 1^2 + 2^2 + 3^2 + … + n^2 = n (n+1) (2n+1)/6
现在考虑较一般点的问题
Sp (n) = 1^p + 2^p+ 3^p + … + n^p (p是正整数)
输入 n,p;
输出结果;
???
编程思想???

[此贴子已经被作者于2007-10-19 18:20:49编辑过]

搜索更多相关主题的帖子: 自然数 高次幂 公式 整数 求和 
2007-10-19 17:06
coding
Rank: 1
等 级:新手上路
威 望:1
帖 子:60
专家分:0
注 册:2007-9-30
收藏
得分:0 
如果单纯从数学公式来说,
进一步推导是用二项公式做的
比如说吧:
1. (1+n)^p-(n)^p=a0+a1s(1)+a2s(2)+...+ap-1s(p-1)
2. (n)^p-(n-1)^p=a0+a1s(1)+a2s(2)+...+ap-1s(p-1)
3. (n-1)^p-(n-2)^p=a0+a1s(1)+a2s(2)+...+ap-1s(p-1)
..
n. (2)^p-1^p=a0+a1s(1)+a2s(2)+...+ap-1s(p-1)

再把所有的项相加就可以了,实际上就是利用前s(1),s(2),...,s(n-1)的公式来求s(n)
对于(1+n)^p-(n)^p=(c(p,0)+c(p,1)*n+c(p,2)*n^2,...+c(p,p)*n^p-n^p)
就可以求得:
(1+n)^p-1^p=c(p,0)s(0)+c(p,1)*s(1)+c(p,2)*s(2)+c(p,p-1)*n^p;
所以很容易就算得了三阶,四阶,五阶。。。的公式了
如果是编的话,可以用这个递推公式来做了,
但是,我觉得还是直接算来得方便,而且简单
不用递推公式:
#include <iostream.h>
long fnsub(n,p)
{ long fresult=n;
long i=1;
for(i=1;i<=p;i++)
fresult*=i;
return fresult;
}

void main()
{
int p;
long num;
cout<<"num:"<<endl;
cin>>num>>p;
for(int i=1;i<=num;i++)
fs=fs+fnsub(i,p) ;
cout<<fs<<endl;
}



2007-10-19 17:48
msshadow
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2007-5-30
收藏
得分:0 

谢谢,我想想..

2007-10-19 17:52
msshadow
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2007-5-30
收藏
得分:0 
回复:(coding)如果单纯从数学公式来说,进一步推导...
但是好像是不行的哦...
2007-10-19 18:25
xhtang
Rank: 1
等 级:新手上路
帖 子:50
专家分:0
注 册:2007-10-1
收藏
得分:0 

[CODE]
void main()
{
double sum = 1, total = 0;
int n, p;
scanf("%d%d", &n, &p);

for (int i=1; i<=n; i++)
{

for (int j=1; j<=p; j++)
{
sum = sum * i;

}
total = total + sum;
sum = 1;
}

printf("sum = %.1f \n", total);
}

[/CODE]


帮助别人是我的快乐! 别人帮我,我心存感激!
2007-10-19 20:01
msshadow
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2007-5-30
收藏
得分:0 
#include<iostream>
using namespace std;
double fun(int n,int p)
{
double i;
double m=1;
for(i=1;i<=p;i++)
m*=n;
return m;
}
int main()
{
double n,p,i;
long ans=0;
cin>>p>>n;
for(i=1;i<=n;i++)
ans+=fun(i,p);
cout<<ans<<endl;
return 0;
}
怎么解决输出是科学计数的问题呢????
2007-10-21 15:37
msshadow
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2007-5-30
收藏
得分:0 
回复:(msshadow)关于自然数的高次幂的问题
请教一下...怎么解决输出是科学计数的问题呢?
2007-10-21 15:46
雨中飞燕
Rank: 3Rank: 3
等 级:禁止访问
威 望:8
帖 子:2200
专家分:0
注 册:2007-8-9
收藏
得分:0 
那你要输出什么?



by 雨中飞燕 QQ:78803110 C/C++讨论群:46520219
Blog: http://yzfy.programfan.com

[url=http://bbs.bc-cn.net/viewthread.php?tid=163571]请大家不要用TC来学习C语言,点击此处查看原因[/url] [url=http://blog.programfan.com/article.asp?id=24801]请不要写出非int声明的main函数[/url]
[url=http://bbs.bc-cn.net/viewthread.php?tid=162918]C++编写的Windows界面游戏[/url]
2007-10-21 15:48
msshadow
Rank: 1
等 级:新手上路
帖 子:40
专家分:0
注 册:2007-5-30
收藏
得分:0 

输出的不要科学计数,要精确的值啊;
比如:
8 9999
111061117777777731111111333333333000

2007-10-21 15:55
雨中飞燕
Rank: 3Rank: 3
等 级:禁止访问
威 望:8
帖 子:2200
专家分:0
注 册:2007-8-9
收藏
得分:0 
那就用高精度



by 雨中飞燕 QQ:78803110 C/C++讨论群:46520219
Blog: http://yzfy.programfan.com

[url=http://bbs.bc-cn.net/viewthread.php?tid=163571]请大家不要用TC来学习C语言,点击此处查看原因[/url] [url=http://blog.programfan.com/article.asp?id=24801]请不要写出非int声明的main函数[/url]
[url=http://bbs.bc-cn.net/viewthread.php?tid=162918]C++编写的Windows界面游戏[/url]
2007-10-21 16:00
快速回复:关于自然数的高次幂的问题
数据加载中...
 
   



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

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