如何解决计算器程序中浮点数不能准确存储的问题
写了一个计算器,可是有些浮点数不能准确存储如何解决这个问题?求大神指教。#include<stdio.h>#include<stdlib.h>
#include<ctype.h>
#include<string.h>
#include<math.h>
#define MAX 100
voidshu(char *p,float *s, int n) //取出z数组中的数字存放到s数组。
{
int i, k = 0, j = 0;
char temp = {0}; //用来临时存放要计算的数字字符
for(i = 0;i < n;i++)
{
if(isalnum(p)||p=='.')
{
temp = p;
k++;
}
else
{
s = atof(temp);
memset(temp, 0, k);
k = 0;
j++;
}
}
s = atof(temp);
}
void fu(char *p,char *f,int n)//取出z数组中的运算符放到f数组。
{
int i, j = 0;
for(i = 0;i < n;i++)
{
if(p == '+' || p == '-' || p == '*' || p == '/')
{
f = p;
j++;
}
}
}
void ji(float *s, char *f,char *z) //计算表达式。
{
int len, i = 0, k;
len = strlen(f);
while(f != '\0')
{
if(f == '*' || f == '/')
{
if(f == '*')
s = s * s;
else
s = s / s;
for(k = i+1;k <= len;k++)
{
s = s;
f = f;
}
i = 0;
}
else
i++;
}
i = 0;
len = strlen(f);
while(f != '\0')
{
if(f == '+')
s = s + s;
else if(f == '-')
s = s - s;
for(k=i+1;k <= len;k++)
{
s = s;
f = f;
}
}
printf("%s = %0.2f", z , s);
getchar();
}
int main(void)
{
int i, len;
char ch;
char z = {0};//用来存放用户输入的运算式。
char f = {0};//用来存放z数组中的运算符。
float s = {0}; //用来存放z数组中的数字。
printf("请输入要计算的式子:\n");
ch=getchar();
for(i = 0; ch !='\n'; i++)
{
z = 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数组)来模拟浮点数 没有人么?
页:
[1]