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