鱼C论坛

 找回密码
 立即注册
查看: 2419|回复: 2

如何解决计算器程序中浮点数不能准确存储的问题

[复制链接]
发表于 2014-8-26 23:17:05 | 显示全部楼层 |阅读模式
5鱼币
写了一个计算器,可是有些浮点数不能准确存储如何解决这个问题?求大神指教。
#include<stdio.h>
#include<stdlib.h>
#include<ctype.h>
#include<string.h>
#include<math.h>

#define MAX 100

void  shu(char *p,float *s, int n) //取出z数组中的数字存放到s数组。
{
        int i, k = 0, j = 0;
        char temp[MAX] = {0};         //用来临时存放要计算的数字字符
        
    for(i = 0;i < n;i++)
        {
                if(isalnum(p[i])||p[i]=='.')
                {
                        temp[k] = p[i];
                        k++;
                }
                else 
                {
                        s[j] = atof(temp);
                        memset(temp, 0, k);
                        k = 0;
                        j++;
                        
                }
        }
        s[j] = atof(temp);
}



void fu(char *p,char *f,int n)  //取出z数组中的运算符放到f数组。
{
        int i, j = 0;
        
        for(i = 0;i < n;i++)
        {
                if(p[i] == '+' || p[i] == '-' || p[i] == '*' || p[i] == '/')
                {
                        f[j] = p[i];
                        j++;
                }
                
        }
        
}



void ji(float *s, char *f,char *z)   //计算表达式。
{
        int len, i = 0, k;
        
        len = strlen(f);
    while(f[i] != '\0')
        {
                if(f[i] == '*' || f[i] == '/')
                {
                        if(f[i] == '*')
                                s[i] = s[i] * s[i+1];
                        else
                                s[i] = s[i] / s[i+1];
                        for(k = i+1;k <= len;k++)
                        {
                                s[k] = s[k+1];
                                f[k-1] = f[k];
                        }
                        i = 0;
                }
                else
                        i++;
        }
        
        i = 0;
        len = strlen(f);
        while(f[i] != '\0')
        {
                if(f[i] == '+')
                        s[i] = s[i] + s[i+1];
                else if(f[i] == '-')
                        s[i] = s[i] - s[i+1];
                for(k=i+1;k <= len;k++)
                {
                        s[k] = s[k+1];
                        f[k-1] = f[k];
                }
        }
        
        printf("%s = %0.2f", z , s[0]);
        
        getchar();
        
        
        
}



int main(void)
{
        int i, len;
        char ch;
        char z[MAX] = {0};  //用来存放用户输入的运算式。
        char f[MAX] = {0};  //用来存放z数组中的运算符。
        float s[MAX] = {0}; //用来存放z数组中的数字。 

        
        printf("请输入要计算的式子:\n");
        
        
        ch=getchar();
        for(i = 0; ch !='\n'; i++)
        {
                z[i] = ch;
                ch = getchar();
        }
        
        
        len=strlen(z);   //计算用户输入字符数组长度
        shu (z, s, len); //取数字
        fu (z, f, len);  //去运算符
        ji (s, f, z);    //计算结果并输出
        
        
        return 0;
}

最佳答案

查看完整内容

浮点数的表示范围是负无穷,到正无穷,而浮点数要么是4字节,要么是8字节。用有限字节表示无限的数,就不可能准确表示。所以要准确表示,就不能用float和double,而要用多个int(火int数组)来模拟浮点数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2014-8-26 23:17:06 | 显示全部楼层
浮点数的表示范围是负无穷,到正无穷,而浮点数要么是4字节,要么是8字节。用有限字节表示无限的数,就不可能准确表示。所以要准确表示,就不能用float和double,而要用多个int(火int数组)来模拟浮点数
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

 楼主| 发表于 2014-8-27 19:33:50 | 显示全部楼层
没有人么?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

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

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-11-24 21:38

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

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