【C语言】求n!位数m,并为其分配空间,但程序输入大于16之后的数就不对了,求大神指教

#include<stdio.h>#include<malloc.h>#include<math.h>intmain(){intn,m,t,i,j,x=1;int*a=(... #include<stdio.h>
#include <malloc.h>
#include<math.h>
int main()
{
int n,m,t,i,j,x=1;
int *a=(int *)malloc(m*sizeof(int));
printf("请输一个小于等于1000正整数n:");
scanf("%d",&n);
if (n<=0||n>1000)
printf ("data error! \n");
else
for(i=1;i<=n;i++)
x*=i;
m=log10(x)+1;
t=m-1;
for(i=t;i>=0;i--)
{
t=x%10;
x/=10;
a[i]=t;

}
printf("储存了一个%d位的正整数:\n",m);
for(i=0;i<m;i++)
printf("%d",a[i]);
printf("\n");
return 0;
}
展开
 我来答
porker2008
推荐于2016-05-23 · TA获得超过1.4万个赞
知道大有可为答主
回答量:7066
采纳率:62%
帮助的人:1.1亿
展开全部
#include <stdio.h>
#include <malloc.h>
#include <math.h>
#include <string.h>
int main()
{
int n, m, t, i, j, x = 1;
int a[4000];
printf("请输一个小于等于1000正整数n:");
scanf("%d", &n);
if (n <= 0 || n > 1000) {
printf("data error! \n");
return -1;
}
else {
memset(a, 0, sizeof(a));
a[0] = 1;
m = 1;
for (i = 1; i <= n; i++) {
x = 0;
for (j = 0; x || j < m; j++) {
a[j] = a[j] * i + x;
x = a[j] / 10;
a[j] = a[j] % 10;
if (j >= m) {
m = j + 1;
}
}
}
}
for (i = 0, j = m - 1; i < j; i++, j--) {
t = a[i];
a[i] = a[j];
a[j] = t;
}
printf("储存了一个%d位的正整数:\n", m);
for (i = 0; i < m; i++)
printf("%d", a[i]);
printf("\n");
return 0;
}
更多追问追答
追问
好厉害!可是要使用malloc函数怎么做呢?作业要求用这个。。。上面那个看不懂哎。。
追答
int a[4000];

改为

int *a = (int*)malloc(sizeof(int) * 4000);

程序结束记得补上

free(a);
百度网友b191f26bc
2014-06-13 · TA获得超过187个赞
知道答主
回答量:173
采纳率:100%
帮助的人:138万
展开全部
怎么个不对法?
如果是忽然出现一个很离谱而且很大的数或很小的负数,那么,恭喜你,溢出了。表示int无法满足你的计数要求,试试double
追问
怎么改 呢?可是x就是整型啊,刚刚改了double类型出问题了,强制类型转换也有问题,刚刚改了长整型也不对,求指点怎么改QAQ
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
summer潇潇烟雨
2014-06-13 · TA获得超过179个赞
知道答主
回答量:100
采纳率:0%
帮助的人:64.3万
展开全部
int的字节不够16的阶乘,改为double就可以了
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
亮仔同学
2014-06-13 · 超过10用户采纳过TA的回答
知道答主
回答量:28
采纳率:0%
帮助的人:24.9万
展开全部
有两个问题 :
1.int *a=(int *)malloc(m*sizeof(int));m没赋值 a申请空间不对

2.x为有符号的int类型,16次以后已经超出其范围,所以结果不对。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
在石门涧看德甲的蓝精灵
2014-06-13 · TA获得超过211个赞
知道答主
回答量:146
采纳率:0%
帮助的人:56.1万
展开全部
结成结果数字过大,溢出了。
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式