下面的代码是我的子程序,用于进行反向抛光记谱法计算......基本上是+, - ,*和/。一切都在程序中工作,除非我尝试添加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;
答案 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)
这是真的。
引擎会将浮点数转换为整数。我想你正在做这样的事情。
查找变量定义。