#include<stdio.h>
void main (void)
{
int a=1;
int i;
for (i=1;i<=35;a=a*i)
{printf ("%d!=%d\n",i,a);
i++;
}
}
哪里错了 啊???
第1个回答 2013-07-23
数有点大,会溢出出错,
可以改成double型数据试试
#include<stdio.h>
void main (void)
{
double a=1;
int i;
for (i=1;i<=35;a=a*(double)i)
{printf ("%d!=%lf\n",i,a);
i++;
}
}
可以改成double型数据试试
#include<stdio.h>
void main (void)
{
double a=1;
int i;
for (i=1;i<=35;a=a*(double)i)
{printf ("%d!=%lf\n",i,a);
i++;
}
}
第2个回答 2013-07-23
首先不管你的程序对不对int型的数据存储35的阶乘基本上来说肯定溢出所以你的数据类型定义的就有问题
第3个回答 推荐于2018-04-05
计算结果超出int所能表示的范围了!
C语言的int类型与开发环境平台有关,可能是16位(2^16),也可能是32位(2^32),估计现在大多数开发环境都是用32位的,可达到4294967296,相当于long int。但你的程序计算结果却大于这个数,因此无法显示。
解决办法:
可以把计算结果不用整形表示,用double长浮点数,计算结果中不保留小数点后面的位数就行了,改成如下,已经试验通过。
#include<stdio.h>
void main (void)
{
double a=1;
int i;
for (i=1;i<=35;a=a*i)
{printf ("%d!=%.lf\n",i,a);
i++;
}
}本回答被提问者和网友采纳
C语言的int类型与开发环境平台有关,可能是16位(2^16),也可能是32位(2^32),估计现在大多数开发环境都是用32位的,可达到4294967296,相当于long int。但你的程序计算结果却大于这个数,因此无法显示。
解决办法:
可以把计算结果不用整形表示,用double长浮点数,计算结果中不保留小数点后面的位数就行了,改成如下,已经试验通过。
#include<stdio.h>
void main (void)
{
double a=1;
int i;
for (i=1;i<=35;a=a*i)
{printf ("%d!=%.lf\n",i,a);
i++;
}
}本回答被提问者和网友采纳
第4个回答 2013-07-23
会溢出、double a;就好了