标题:关于int和float的问题
取消只看楼主
x葱
Rank: 1
等 级:新手上路
帖 子:2
专家分:0
注 册:2012-2-29
结帖率:100%
已结贴  问题点数:20 回复次数:0 
关于int和float的问题
我刚学习c语言,在c++6.0上写了这个小程序发现输出结果是个错误的数而,M改成9999或者将N改成10000就能输出正确结果了,这是和int的范围有关吗?
#include <stdio.h>
#define N 100000
#define M 99999
int main()
{
    int z;
    z=N*M;
    printf("M*N=%d\n",z);
    return 0;
}
但是我将z改成浮点型,将M,N也转化成浮点型为什么就能输出正确结果了?浮点型的可以指定的数据宽度最大是多少啊?
#include <stdio.h>
#define N 100000
#define M 99999
int main()
{
    float x,y,z;
    x=N;
    y=M;
    z=x*y;
    printf("M*N=%10.0f\n",z);
    return 0;
}
搜索更多相关主题的帖子: c语言 青少年 
2012-02-29 22:11



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-361908-1-1.html




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

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