| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1336 人关注过本帖
标题:[求助]请教大家.(已解决)
只看楼主 加入收藏
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 

比如是1000!
double sum=0;
那就是for(i=1;i<=1000;i++)
{
sum+=log10(i);
}
printf("%ld\n",(long)sum+1);


倚天照海花无数,流水高山心自知。
2006-11-05 23:18
minute
Rank: 1
等 级:新手上路
帖 子:6
专家分:0
注 册:2006-11-6
收藏
得分:0 
这个是加法
sum+扩展的一种,可以把sum+=函数(i),归纳可以得到很多种的。
关键看平时的积累了。
2006-11-06 03:20
suifengjita
Rank: 1
等 级:新手上路
帖 子:35
专家分:0
注 册:2006-10-12
收藏
得分:0 
[QUOTE]double sum=0;
for(i=1;i<=1000;i++)
{
sum+=log10(i);
}
printf("%ld\n",(long)sum+1);[/QUOTE]
相当简洁!
2006-11-06 11:16
风诗血
Rank: 1
等 级:新手上路
帖 子:1
专家分:0
注 册:2006-11-6
收藏
得分:0 

好方法,不需要算阶乘

2006-11-06 22:11
C语言学习者
Rank: 4
等 级:贵宾
威 望:13
帖 子:1278
专家分:0
注 册:2006-9-26
收藏
得分:0 
本人数学要有待提高才行

谁有强殖装甲第二部,可以Q我460054868
2006-11-06 22:14
Donie
Rank: 1
等 级:新手上路
帖 子:37
专家分:0
注 册:2006-11-2
收藏
得分:0 

为什么啊?
可不可以从数学角度证明一下

2006-11-06 22:50
shuaiye
Rank: 1
等 级:新手上路
帖 子:445
专家分:0
注 册:2006-5-15
收藏
得分:0 
[QUOTE]为什么啊?
可不可以从数学角度证明一下
[/QUOTE]

对数运算法则:

设有一函数 Y=X×(X-1);

两边取(常用)对数:

lgY=lg(X*(X-1)=lgX+lg(X-1).

由于工作,N久都没来了!
2006-11-07 01:38
sdrzw
Rank: 1
等 级:新手上路
帖 子:18
专家分:0
注 册:2006-11-4
收藏
得分:0 
然后呢?

藏锋守拙磨利剑,一心学好C语言
2006-11-07 16:07
nuciewth
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:我爱龙龙
等 级:贵宾
威 望:104
帖 子:9786
专家分:208
注 册:2006-5-23
收藏
得分:0 
我来说明一下.对一个数的阶乘的位数.可以用log10()来求和是这样的.

我们都知道有这样的公式log10(X*Y)=log10(X)+log10(Y).
那很显然log10(1*2*3*4...*n)=log10(1)+...log10(n)了.
再证一个数的位数=(long)log10(n)+1.
我们都知道log10()是对10取对数,即假设有一个整数n,则log10(10^x)-(long)log10(n)=1成立,(这里x表示为n的位数.)
故x=(long)log10(n)+1;(这里只限于对log10()运算取整成立.)

倚天照海花无数,流水高山心自知。
2006-11-07 16:35
C语言学习者
Rank: 4
等 级:贵宾
威 望:13
帖 子:1278
专家分:0
注 册:2006-9-26
收藏
得分:0 
等效思想.

谁有强殖装甲第二部,可以Q我460054868
2006-11-07 16:41
快速回复:[求助]请教大家.(已解决)
数据加载中...
 
   



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

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