浮动加2.5 + 2.5 = 4.0? RPN

时间:2012-09-18 02:46:29

标签: c calculator rpn

下面的代码是我的子程序,用于进行反向抛光记谱法计算......基本上是+, - ,*和/。一切都在程序中工作,除非我尝试添加2.5和2.5程序给我4.0 ...我想我知道为什么,但我不知道如何解决它...现在我正在阅读所有这个赋值所需的命令行中的数字和运算符,然后取出该字符串并使用sscanf从中获取数字...我想某种方式包含三个字符'2','。'的数组,并且'5',并没有被完全转换成浮点数...相反,我认为只是'2'。有人可以看看我的代码并确认或否认这一点,并可能告诉我如何解决它,以便我得到正确的答案?提前感谢您的帮助!

float
fsm (char mystring[])
{
  int i = -1, j, k = 0, state = 0;
  float num1, num2, ans;
  char temp[10];
  c_stack top;
  c_init_stack (&top);
  while (1)
    {
      switch (state)
    {
    case 0:
      i++;
      if ((mystring[i]) == ' ')
        {
          state = 0;
        }
      else if ((isdigit (mystring[i])) || (mystring[i] == '.'))
        {
          state = 1;
        }
      else if ((mystring[i]) == '\0')
        {
          state = 3;
        }
  else
    {
      state = 4;
    }
  break;
case 1:
  temp[k] = mystring[i];
  k++;
  i++;
  if ((isdigit (mystring[i])) || (mystring[i] == '.'))
    {
      state = 1;
    }
  else
    {
      state = 2;
    }
  break;
case 2:
  temp[k] = '\0';
  sscanf (temp, "%f", &num1);
  c_push (&top, num1);
  i--;
  k = 0;
  state = 0;
  break;
case 3:
  ans = c_pop (&top);
  if (c_is_empty (top))
    return ans;
  else
    {
      printf ("There are still items on the stack\n");
      exit (0);
case 4:
      num2 = c_pop (&top);
      num1 = c_pop (&top);
      if (mystring[i] == '+'){
          ans = num1 + num2;
        return ans;
    }
      else if (mystring[i] == '-'){
    ans = num1 - num2;
    return ans;
    }
      else if (mystring[i] == '*'){
    ans = num1 * num2;
    return ans;
    }
      else if (mystring[i] == '/'){
          if (num2){
            ans = num1 / num2;
            return ans;
        }
      else{
        printf ("Error: cannot divide by 0\n");
        exit (0);
          }
    }
      c_push (&top, ans);
      state = 0;
      break;
    }
}
}
}

这是我的主要计划:

#include <stdio.h>
#include <stdlib.h>
#include "boolean.h"
#include "c_stack.h"
#include <string.h>

int main(int argc, char *argv[])
{
  char mystring[100];
  int i;
  sscanf("", "%s", mystring);
  for (i=1; i<argc; i++){
   strcat(mystring, argv[i]);
   strcat(mystring, " ");
   }
  printf("%.2f\n", fsm(mystring));
  }

这是带有原型的头文件和c_stack的定义:

#include "boolean.h"

#ifndef CSTACK_H
#define CSTACK_H

  typedef struct c_stacknode{
  char data;
  struct c_stacknode *next;
  } *c_stack;

#endif

void c_init_stack(c_stack *);
boolean c_is_full(void);
boolean c_is_empty(c_stack);
void c_push(c_stack *,char);
char c_pop(c_stack *);
void print_c_stack(c_stack);
boolean is_open(char);
boolean is_brother(char, char);
float fsm(char[]);

回应六个变量:

赋值的一部分是在数组中使用带有数字和小数的现有字符串,并使用它们创建一个浮点数,这就是我在这些代码行中所做的事情:

case 1:
 temp[k] = mystring[i];
 k++;
 i++;
 if ((isdigit (mystring[i])) || (mystring[i] == '.')) {
 state = 1; } else {
  state = 2;
 }
 break;
 case 2:
 temp[k] = '\0';
 sscanf (temp, "%f", &num1);
 c_push (&top, num1);
 i--;
 k = 0; 
 state = 0;
 break;

3 个答案:

答案 0 :(得分:4)

您的堆栈存储char数据:

typedef struct c_stacknode{
char data;
struct c_stacknode *next;
} *c_stack;
根据定义,

char不存储浮点数据。相反,当您调用c_push,将2.5截断为2时,就会发生整数转换。

您需要更新struct c_stacknode及其相关方法系列的定义,以支持float数据。

答案 1 :(得分:1)

您还可以分享c_stack的定义吗?看起来它是一个整数类型的堆栈,向下舍入任何浮点输入。这样,2.5 + 2.5 == 4

答案 2 :(得分:0)

如果您将变量定义为

int x=2.5;

int y=2.5;

稍后你会做出像

这样的事情
if((x+y)==4.0)

这是真的。

引擎会将浮点数转换为整数。我想你正在做这样的事情。

查找变量定义。