解题思路:C语言栈的应用

注意事项:

参考代码:

#include<stdio.h>
#include<stdlib.h>
#define maxsize 100
#define Etype double
#define Stype char

typedef struct {
 Etype* base;
 Etype* top;
 int size;
}data1;    //操作数栈

typedef struct {
 Stype* base;
 Stype* top;
 int size;
}data2;     //运算符栈

int initstack1(data1* s)
{
 s->base = (Etype*)malloc(sizeof(Etype) * maxsize);
 if (!s->base)
 {
  exit(0);
  return 0;
 }
 else
 {
  s->top = s->base;
  s->size = maxsize;
  return 1;
 }
}

int initstack2(data2* s)
{
 s->base = (Stype*)malloc(sizeof(Stype) * maxsize);
 if (!s->base)
 {
  exit(0);
  return 0;
 }
 else
 {
  s->top = s->base;
  s->size = maxsize;
  return 1;
 }
}

int getstack1(data1* s, Etype* x)
{
 if (s->top == s->base)
  return 0;
 else
 {
  *x = *(s->top - 1);
  return 1;
 }
}

int getstack2(data2* s, Stype* x)
{
 if (s->top == s->base)
  return 0;
 else
 {
  *x = *(s->top - 1);
  return 1;
 }
}

int pop1(data1* s, Etype* x)
{
 if (s->top == s->base)
  return 0;
 else
 {
  *x = *--s->top;
  return 1;
 }
}

int pop2(data2* s, Stype* x)
{
 if (s->top == s->base)
  return 0;
 else
 {
  *x = *--s->top;
  return 1;
 }
}

int push1(data1* s, Etype x)
{
 if (s->top - s->base == maxsize)
  return 0;
 else
 {
  *s->top++ = x;
  return 1;
 }
}

int push2(data2* s, Stype x)
{
 if (s->top - s->base == maxsize)
  return 0;
 else
 {
  *s->top++ = x;
  return 1;
 }
}

double fun(double n, double m, char e)
{
 double sum=0;

 switch (e)
 {
 case '+':sum = n + m; break;
 case '-':sum = n - m; break;
 case '*':sum = n * m; break;
 case '/':sum = n / m; break;
 }

 return sum;
}

int empty(data2* s2)
{
 if (s2->top == s2->base)
  return 0;
 else
  return 1;
}

int main()
{
 char s[100], e, ch;
 int k, n;
 double num, x, y, m;
 data1 s1;
 data2 s2;
 initstack1(&s1);
 initstack2(&s2);

 while ((ch = getchar()) != EOF)
 {
  if (ch == '#')
  {
   while (empty(&s2))
   {
    pop2(&s2, &e);
    pop1(&s1, &x);
    pop1(&s1, &y);
    m = fun(y, x, e);
    push1(&s1, m);
   }
   pop1(&s1, &x);
   printf("%d\n", (int)x);
  }

  if (ch != '#')
  {
   k = 0;
   while (ch >= '0' && ch <= '9' || ch == '.')
   {
    s[k++] = ch;
    ch = getchar();
   }

   if (k != 0)
   {
    s[k] = 0;
    num = atof(s);
    push1(&s1, num);
   }

   if (ch == '*' || ch == '/')
   {
    n = getstack2(&s2, &e);
    if (n == 0 || e == '+' || e == '-' || e == '(')
     push2(&s2, ch);
    else if (e == '*' || e == '/')
    {
     do {
      pop2(&s2, &e);
      pop1(&s1, &x);
      pop1(&s1, &y);
      m = fun(y, x, e);
      push1(&s1, m);
      n = getstack2(&s2, &e);
     } while (n && e != '+' && e != '-' && e != '(');

     push2(&s2, ch);
    }
   }

   else if (ch == '+' || ch == '-')
   {
    n = getstack2(&s2, &e);
    if (n == 0 || e == '(')
     push2(&s2, ch);
    else
    {
     while (n != 0 && e != '(')
     {
      pop2(&s2, &e);
      pop1(&s1, &x);
      pop1(&s1, &y);
      m = fun(y, x, e);
      push1(&s1, m);
      n = getstack2(&s2, &e);
     }
     push2(&s2, ch);
    }
   }

   else if (ch == ')')
   {
    pop2(&s2, &e);
    while (e != '(')
    {
     pop1(&s1, &x);
     pop1(&s1, &y);
     m = fun(y, x, e);
     push1(&s1, m);
     pop2(&s2, &e);
    }
   }

   else if (ch == '(')
   {
    push2(&s2, ch);
   }

   if (ch == '#')
   {
    while (empty(&s2))
    {
     pop2(&s2, &e);
     pop1(&s1, &x);
     pop1(&s1, &y);
     m = fun(y, x, e);
     push1(&s1, m);
    }
    pop1(&s1, &x);
    printf("%d\n", (int)x);
   }
  }


 }

 return 0;
}


点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论