找回密码
 注册
搜索
热搜: 回贴
  • 前程无忧官网首页 有什么好的平台可以
  • 最新的销售平台 互联网营销的平台有哪
  • 制作网页的基本流程 网页制作和网页设
  • 【帝国CMS】输出带序号的列表(数字排
  • 网站建设公司 三一,中联,极东泵车的
  • 织梦 建站 织梦网站模版后台怎么更改
  • 云服务官网 哪些网站有免费的简历模板
  • 如何建网站要什么条件 建网站要用什么
  • 吉林市移动公司电话 吉林省退休人员网
  • 设计类毕业论文 网站设计与实现毕业论
查看: 1963|回复: 2

大家看下?

[复制链接]
发表于 2009-10-31 02:11:43 | 显示全部楼层 |阅读模式 IP:江苏扬州
求1000的阶乘?实在找不出错误在哪里?下面的代码通过的编译,但是结果是错误!!哪位帮帮看看哪错了!!
#include<iostream>
#include<stdlib.h>
using namespace std;
void Change(int a[] , int m) ;
int main()
{
int a[3000] = {0} ;
a[0] = 1 ;
int m , n , b=0 ;
for(int i=2 ; i<=1000 ; i++) //这个循环实现1000的阶乘
{
for(int j=2999 ; j>=0 ; j--) //这个循环是求出最高位m (即不为零数的最高位)
{
if(a[i] != 0)
{
m = i ;
break ;
}
}

for(int j=0 ; j<= m ; j++) //把每一个元素分别乘以i,并保存在原来的位置
{ a[j] = a[j] * i ;}

Change(a , m) ; //对上面的每个元素分别做调整 ,每乘一次做一次调整

}

for(int j=2999 ; j>=0 ; j--) //求出结果的最高位,以便输出(避免的在输出结果中前面有一大堆的零)
{
if(a[j] != 0)
{
n = j ;
break ;
}
}

for(int l=n ; l>=0 ; l--) //输出结果
cout << a[l] ;
cout << endl ;
system("pause") ;
}

void Change(int a[] , int m)
{
int b = 0 ; //b表示低位向高位的进位
for(int i=0 ; i<=m ; i++)
{
a[i] = a[i] + b ;
if(a[i] < 9) //当a[i]<9时,说明这里不做进位处理
{
b = 0 ;
}
if(a[i] > 9 && i != m) //当a[i]不是最高位时,满足条件只进位
{
b = a[i] / 10 ;
a[i] = a[i] % 10 ;
}
if(a[i] > 9 && i == m) // 当a[i]是最高位时 ,满足条件要做相应的处理
{
while(a[i] > 9)
{
b = a[i] / 10 ;
a[i] = a[i] % 10 ;
i++ ;
a[i] = b ;
}
// b = 0 ;
}
}
}
发表于 2009-10-31 02:11:44 | 显示全部楼层 IP:江苏扬州
求阶乘有这么复杂吗?
回复

使用道具 举报

发表于 2009-10-31 02:11:44 | 显示全部楼层 IP:江苏扬州
我想不该有这么复杂吧……
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则

QQ|小黑屋|最新主题|手机版|微赢网络技术论坛 ( 苏ICP备08020429号 )

GMT+8, 2024-9-29 17:28 , Processed in 0.262139 second(s), 12 queries , Gzip On, MemCache On.

Powered by Discuz! X3.5

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表