鱼C论坛

 找回密码
 立即注册
查看: 3112|回复: 0

[学习笔记] RPN计算

[复制链接]
发表于 2019-1-7 20:27:02 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
  1. #include <stdlib.h>
  2. #include <stdio.h>
  3. #include <ctype.h>

  4. #define STACK_INIT_SIZE 20
  5. #define STACKINCREAMENT 10
  6. #define MAXBUFFER 10

  7. typedef double ElementType;

  8. typedef struct {
  9.         ElementType* base;
  10.         ElementType* top;
  11.         int stackSize;
  12. }sqStack;

  13. void InitStack(sqStack* s);
  14. bool StackEmpty(sqStack* s);
  15. void Push(sqStack* s, double e);
  16. void Pop(sqStack* s, double* e);

  17. int main()
  18. {
  19.         sqStack* s = (sqStack*)malloc(sizeof(sqStack*));
  20.         InitStack(s);
  21.         char buffer[MAXBUFFER];
  22.         char c = '0';
  23.         double left, right, result;
  24.         printf("Please input a string of RPN expression, the # character ends up with the input\n");
  25.         while (true) {
  26.                 int i = 0;
  27.                 while (1) {
  28.                         scanf("%c", &c);
  29.                         if (isdigit(c)||c == '.') {
  30.                                 buffer[i++] = c;
  31.                         }
  32.                         else if(c == ' ' && i != 0){
  33.                                 buffer[i] = '\0';
  34.                                 double value = atof(buffer);
  35.                                 Push(s, value);
  36.                                 break;
  37.                         }
  38.                         else {
  39.                                 break;
  40.                         }
  41.                 }
  42.                 switch (c) {
  43.                 case '+':
  44.                         Pop(s, &left);
  45.                         Pop(s, &right);
  46.                         Push(s, left+right);
  47.                         break;
  48.                 case '-':
  49.                         Pop(s, &right);
  50.                         Pop(s, &left);
  51.                         Push(s, left - right);
  52.                         break;
  53.                 case '*':
  54.                         Pop(s, &right);
  55.                         Pop(s, &left);
  56.                         Push(s, left * right);
  57.                         break;
  58.                 case '/':
  59.                         Pop(s, &right);
  60.                         Pop(s, &left);
  61.                         if (right == 0.0) {
  62.                                 printf("The divisor is not equal to zero\n");
  63.                         }
  64.                         Push(s, left/right);
  65.                         break;
  66.                 default :
  67.                         break;
  68.                 }
  69.                 if (c == '#') {
  70.                         break;
  71.                 }
  72.         }
  73.         Pop(s, &result);
  74.         printf("The final result is %lf\n", result);
  75.         return 0;
  76. }
  77. void InitStack(sqStack* s) {
  78.         s->top = s->base = (ElementType*)malloc(STACK_INIT_SIZE * sizeof(double));
  79.         if (!s->top) {
  80.                 exit(0);
  81.         }
  82.         s->stackSize = STACK_INIT_SIZE;
  83. }
  84. bool StackEmpty(sqStack* s) {
  85.         if (s->top == s->base) {
  86.                 return true;
  87.         }
  88.         else {
  89.                 return false;
  90.         }
  91. }
  92. void Push(sqStack* s, double e) {
  93.         if (s->top - s->base >= s->stackSize) {
  94.                 s->base = (ElementType*)realloc(s->base, s->stackSize + STACKINCREAMENT);
  95.                 if (!s->base) {
  96.                         exit(0);
  97.                 }
  98.                 s->stackSize = s->stackSize + STACKINCREAMENT;       
  99.         }
  100.         *(s->top) = e;
  101.         s->top++;

  102. }
  103. void Pop(sqStack* s, double* e) {
  104.         if (StackEmpty(s)) {
  105.                 return;
  106.         }
  107.         *e = *--(s->top);
  108. }
复制代码


小甲鱼最新课程 -> https://ilovefishc.com
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-6-8 19:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表