|
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数组)来模拟浮点数
|