0

如何在我的 RPN 计算器中读取以下输入,以便无论顺序如何都能找到运算符?

2
2+
4

截至目前,我的 scanf 只看到字符串中的第一个字符,我只能这样做:

2
2
+
4

我也在尝试为整数与浮点模式添加一个选项。(例如,当输入“i”时,以浮点运算,反之亦然。)

#include <stdio.h>
#include <stdlib.h>

#define MAX 100

int *p;
int *tos;
int *bos;

void push(int i);
int pop(void);

int main (void)
{
int a, b;
//float c, d;
char s[80];
//char op;  //declare string of 80 chars

p = (int *) malloc(MAX*sizeof(int)); //get stack memory
if (!p){
 printf("Allocation Failure\n");
 exit(1);
 }
 tos = p;
 bos = p + MAX-1;

 printf("\nRPN Calculator\n");
 printf("Enter 'i' for integer mode\n");
 printf("Enter 'f' for floating point mode\n");
 printf("Enter 'q' to quit\n");

 do {
 printf("> ");
 // gets(s);
 // scanf("%s", s);  //read integer
 scanf("%s", s);
 // switch (*s) {


 switch(*s) {
   case 'i':
       printf("(Integer Mode)\n");
   break;
   case 'f':
       printf("(Floating Point Mode)\n");
   break;
   case '+':
       a = pop();
       b = pop();
       printf("%d\n", a+b);
       push(a+b);
   break;
   case '-':
       a = pop();
       b = pop();
       printf("%d\n", b-a);
       push(b-a);
       break; 
  case '*':
       a = pop();
       b = pop();
       printf("%d\n", a*b);
       push(a*b);
  break;
  case '/':
       a = pop();
       b = pop();
       if(a == 0){
         printf("Cannot divide by zero\n");
  break;
  }
       printf("%d\n", b/a);
       push(b/a);
  break;
  case '.':
       a = pop();
       push(a);
       printf("Current value on top of stack: %d\n", a);
  break; 
  default:
       push(atoi(s));
  }

 } while (*s != 'q');

 return 0;
}


 // Put an element on the stack

 void push (int i)
 {
 if (p > bos){
   printf("Stack Full\n");
 return;
 }
  *p = i;
  p++;
 }

// Get the element from the top of the stack

int pop (void)
{
 p--;
 if(p < 0) {
    printf("Stack Underflow\n");
 return 0;
 }
 return *p;
 }
4

3 回答 3

1

scanf读取整个字符串。下面的开关根据第一个字符进行判断并错过+2+.

要改进它,您可以使用该strtol功能。它将从字符串中解析出一个整数并将整数结束的位置返回给您 - 如果那仍然不是字符串的结尾,则那里可能有一个运算符。

浮点数的类似函数是strtod.


strtol这是适用于您的示例的一些示例代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>


int main()
{
    char* input = "25+";
    char* endptr;

    int val = strtol(input, &endptr, 10);

    if (*endptr == '\0')
    {
        printf("Got only the integer: %d\n", val);
    }
    else
    {
        printf("Got an integer %d\n", val);
        printf("Leftover: %s\n", endptr);
    }


    return 0;
}
于 2010-01-28T10:39:08.090 回答
0

我不确定我是否完全理解您的问题,但您可以像这样遍历字符串:

for(i = 0; i < strlen(s); i++)
{
   // Here comes your switch section like this
   switch(s[i]) {
    .....
   }

}

还记得包括 string.h。

于 2010-01-28T10:41:58.630 回答
0

我真的不明白你的代码。

如果希望用户每次输入一个字符,我的意思是一个字符+回车,你应该使用一个简单的 char 而不是 char[]。如果你假装使用一个字符串,你应该接收它并解析它 pzico 说。你可以做这样的事情。问题在于处理多位数的数字,但稍微思考一下就可以解决这个问题。我写了一个尝试,但我很确定它不会工作。

printf("\nRPN 计算器\n");
printf("输入 'i' 为整数模式\n");
printf("输入 'f' 为浮点模式\n");
printf("输入'q'退出\n");
scanf("%c", s);

开关(*s){

case 'i':  
    printf("(Integer Mode)\n");  
break;  
case 'f':  
    printf("(Floating Point Mode)\n");  
break;  
case 'q':  
    printf("Bye Bye\n");  
    return;  
break;  

} printf("每次输入表达式一个字符\n");

做 {

scanf("%c", s);   
switch(s) {   
    case '+':   
        a = pop();      
        b = pop();     
        printf("%d\n", a+b);      
        push(a+b);
    break;
    case '-':
        a = pop();
        b = pop();
        printf("%d\n", b-a);
        push(b-a);
    break; 
    case '*':
        a = pop();
        b = pop();
        printf("%d\n", a*b);
        push(a*b);
    break;
    case '/':
        a = pop();
        b = pop();
        if(a == 0){
            printf("Cannot divide by zero\n");
            break;
        }
        printf("%d\n", b/a);
        push(b/a);
    break;
    case '.':
        a = pop();
        push(a);
        printf("Current value on top of stack: %d\n", a);
    break; 
    default:
        a = pop()*10+atoi(s);
        push(a);
}  

} 而 (s != 'q');

您的代码中的另一个问题是您的 pop 函数。你想用这个测试做什么:

if(p < 0) {
printf("堆栈下溢\n");
返回0;
}

您期望您的指针到达地址 0?

无论如何,我希望这不是你的作业。

于 2010-01-28T12:06:48.060 回答