| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 3627 人关注过本帖
标题:求教:关于赋值float变量后,运行时变量值不对的问题
只看楼主 加入收藏
mk_zhou
Rank: 2
来 自:历代兵家必争之地
等 级:论坛游民
威 望:1
帖 子:78
专家分:83
注 册:2015-6-30
结帖率:84.62%
收藏
已结贴  问题点数:20 回复次数:7 
求教:关于赋值float变量后,运行时变量值不对的问题
程序代码:
/*
企业发放的奖金根据利润提成。利润(I)低于或等于10万元时,奖金可提10%;利润高
于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可可提
成7.5%;20万到40万之间时,高于20万元的部分,可提成5%;40万到60万之间时高于
40万元的部分,可提成3%;60万到100万之间时,高于60万元的部分,可提成1.5%,高于
100万元时,超过100万元的部分按1%提成,从键盘输入当月利润I,求应发放奖金总数?
*/        
#include<stdio.h>
int main()
{
    int i;
    float sum=0,a=0.1,b=0.075,c=0.05,d=0.03,e=0.015,f=0.01;

    scanf("%d",&i);
    if (i<=100000)
    {
        sum=(i*0.1);
    }
    else if (i>100000&&i<=200000)
    {
        sum=(i-100000)*b+100000*0.1;
    }
    else if (i>200000&&i<=400000)
    {
        sum=(i-200000)*d+(200000-100000)*b+100000*0.1;
    }
    else if (i>400000&&i<=600000)
    {
        sum=(i-400000)*d+(400000-200000)*d+(200000-100000)*b+100000*0.1; 
    }
    else if (i>600000&&i<=1000000)
    {
        sum=(i-600000)*e+(600000-400000)*d+(400000-200000)*d+(200000-100000)*b+100000*0.1; 
    }
    else if (i>1000000)
    {
        sum=(i-1000000)*f+(1000000-600000)*e+(600000-400000)*d+(400000-200000)*d+(200000-100000)*b+100000*0.1; 
    }
    printf("%7.2f",sum);
    return 0;
}

以上代码运行时,得到的结果错误,通过调试发现a、b、c、d、e、f几个变量已经和初始值不同,请问是因为什么?
        a    0.100000001        float
        b    0.0750000030    float
        c    0.0500000007    float
        d    0.0299999993    float
        e    0.0149999997    float
        f    0.00999999978    float
搜索更多相关主题的帖子: 键盘 
2016-12-07 01:53
吹水佬
Rank: 16Rank: 16Rank: 16Rank: 16
等 级:版主
威 望:451
帖 子:10607
专家分:43186
注 册:2014-5-20
收藏
得分:0 
以下是引用mk_zhou在2016-12-7 01:53:48的发言:
以上代码运行时,得到的结果错误,通过调试发现a、b、c、d、e、f几个变量已经和初始值不同,请问是因为什么?
        a    0.100000001        float
        b    0.0750000030    float
        c    0.0500000007    float
        d    0.0299999993    float
        e    0.0149999997    float
        f    0.00999999978    float

怎样打印出来的?
2016-12-07 04:59
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:0 
别多想了,先检查代码吧,比如 c=0.05 好像就没用到
2016-12-07 09:09
mk_zhou
Rank: 2
来 自:历代兵家必争之地
等 级:论坛游民
威 望:1
帖 子:78
专家分:83
注 册:2015-6-30
收藏
得分:0 
回复 3楼 rjsp
谢谢,就是因为c没有用到导致最后算出来的值错误。但是还是不明白为什么那几个变量的值为什么和我的赋值不一样

[此贴子已经被作者于2016-12-7 23:06编辑过]


仰望星空,看看有没有馅饼落下
2016-12-07 23:04
mk_zhou
Rank: 2
来 自:历代兵家必争之地
等 级:论坛游民
威 望:1
帖 子:78
专家分:83
注 册:2015-6-30
收藏
得分:0 
回复 2楼 吹水佬
我在第一个if那里打了断点,打印出来的

仰望星空,看看有没有馅饼落下
2016-12-07 23:05
rjsp
Rank: 20Rank: 20Rank: 20Rank: 20Rank: 20
等 级:版主
威 望:528
帖 子:9025
专家分:54030
注 册:2011-1-18
收藏
得分:20 
以下是引用mk_zhou在2016-12-7 23:04:11的发言:

谢谢,就是因为c没有用到导致最后算出来的值错误。但是还是不明白为什么那几个变量的值为什么和我的赋值不一样
浮点数没能力表示出任意的实数,因为浮点数的位数是有限的,而实数在任意小的区间内都有无穷多个。

在金融上,没有人会用浮点数去计算
比如你这题,最小值是0.015,那么可以用“厘”为单位,这样所有数值都是整数。

即使在不重要的统计场合用浮点数,也没人会傻到用float,大家用double时都小心翼翼,通过各种手段防止中间步骤导致精度骤降
2016-12-08 08:51
StadyC
Rank: 6Rank: 6
等 级:侠之大者
威 望:6
帖 子:182
专家分:430
注 册:2016-10-13
收藏
得分:0 
单精度浮点数有时候作运算只是极为接近该数字,而不是等于这个数字。
2016-12-09 09:10
mk_zhou
Rank: 2
来 自:历代兵家必争之地
等 级:论坛游民
威 望:1
帖 子:78
专家分:83
注 册:2015-6-30
收藏
得分:0 
回复 6楼 rjsp
感谢您的解答

仰望星空,看看有没有馅饼落下
2016-12-10 20:20
快速回复:求教:关于赋值float变量后,运行时变量值不对的问题
数据加载中...
 
   



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

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