当前位置: 首页 > wzjs >正文

上海全上海全国网站建设pc端与手机端网站开发的区别

上海全上海全国网站建设,pc端与手机端网站开发的区别,上海本地企业,aso关键词优化计划后缀表达式 后缀表达式是给计算机去看的,一个个压进栈中; 遇到操作符就计算再将计算出的结果压到栈中;最后弹出结果。 1.栈的初始化(动态存储) typedef struct {ElemType* data;int top; }Stack; //初始化 Stack* initStack() {Stack* s (Stack*)malloc(sizeof(Stack));s->…

后缀表达式

后缀表达式是给计算机去看的,一个个压进栈中; 遇到操作符就计算再将计算出的结果压到栈中;最后弹出结果。

1.栈的初始化(动态存储)

typedef struct {ElemType* data;int top;
}Stack;
//初始化
Stack* initStack()
{Stack* s = (Stack*)malloc(sizeof(Stack));s->data = (ElemType*)malloc(sizeof(ElemType) * MAXSIZE);s->top = -1;return s;
}

2.用了一个枚举类型去存储一些操作

typedef enum
{   //左右括号  LEFT_PARE, RIGTH_PARE,ADD,SUB,MUL,DIV,MOD,EOS,NUM 
}contentType;

3.对栈的入栈和出栈操作

// 入栈操作
int push(Stack* s, ElemType elem) {if (s->top == MAXSIZE - 1) {printf("栈满,无法入栈\n");return 0;}s->top++;s->data[s->top] = elem;return 1;
}
int pop(Stack* s, ElemType* elem) {if (s->top == -1) {printf("栈空,无法出栈\n");return 0;}*elem = s->data[s->top];s->top--;return 1;
}

4.对操作数的具体操作

  • 我们来模拟当index = 0时 在 字符数组中下标为0的字符是8 然后可以得到 symbol = '8'

  • 进入switch中可以返回NUM

  • 在eval函数中,token为NUM就识别为数字,就压栈

  • 不断的循环最后完成表达式求值

contentType getToken(char* symbol, int* index)
{*symbol = expr[*index]; //先将0的地址传过来现在值为8*index = *index + 1; //index变2switch (*symbol)//将8存进去{case'(':return LEFT_PARE;case')':return RIGTH_PARE;case'+':return ADD;case'-':return SUB;case'*':return MUL;case'/':return DIV;case'%':return MOD;case'\0':return EOS;default:return NUM;  //数字8 返回NUM}
}
​
int eval(Stack* s)
{char symbol;int op1, op2;int index = 0;contentType token; //字符的类型token = getToken(&symbol, &index);//识别到是哪个字符,返回什么算法ElemType result;while (token != EOS) {//一直循环到字符数组的\0结束if (token == NUM)//如果是数字就压栈{push(s, symbol - '0');// 字符减去'0' 是数值}else{pop(s, &op2); //如果是操作符就弹出进行计算pop(s, &op1);
​switch (token){case ADD:push(s, op1 + op2);break;case SUB:push(s, op1 - op2);break;case MUL:push(s, op1 * op2);break;case DIV:push(s, op1 / op2);break;case MOD:push(s, op1 % op2);break;default:break;}}token = getToken(&symbol, &index);
​}pop(s, &result);printf("%d\n", result);return 1;
}

5.一个全局变量,字符数组

char expr[] = "82/2+56*-";

完整代码如下

#define _CRT_SECURE_NO_WARNINGS 1
#include<stdio.h>
#include<stdlib.h>
#define MAXSIZE 100
typedef int ElemType;typedef struct {ElemType* data;int top;
}Stack;typedef enum
{	//左右括号	LEFT_PARE, RIGTH_PARE,ADD,SUB,MUL,DIV,MOD,EOS,NUM 
}contentType;char expr[] = "82/2+56*-";//初始化
Stack* initStack()
{Stack* s = (Stack*)malloc(sizeof(Stack));s->data = (ElemType*)malloc(sizeof(ElemType) * MAXSIZE);s->top = -1;return s;
}// 入栈操作
int push(Stack* s, ElemType elem) {if (s->top == MAXSIZE - 1) {printf("栈满,无法入栈\n");return 0;}s->top++;s->data[s->top] = elem;return 1;
}
int pop(Stack* s, ElemType* elem) {if (s->top == -1) {printf("栈空,无法出栈\n");return 0;}*elem = s->data[s->top];s->top--;return 1;
}
contentType getToken(char* symbol, int* index)
{*symbol = expr[*index]; //先将0的地址传过来现在值为8*index = *index + 1; //index变2switch (*symbol)//将8存进去{case'(':return LEFT_PARE;case')':return RIGTH_PARE;case'+':return ADD;case'-':return SUB;case'*':return MUL;case'/':return DIV;case'%':return MOD;case'\0':return EOS;default:return NUM;  //数字8 返回NUM}
}int eval(Stack* s)
{char symbol;int op1, op2;int index = 0;contentType token; //字符的类型token = getToken(&symbol, &index);//识别到是哪个字符,返回什么算法ElemType result;while (token != EOS) {//一直循环到字符数组的\0结束if (token == NUM)//如果是数字就压栈{push(s, symbol - '0');// 字符减去'0' 是数值}else{pop(s, &op2); //如果是操作符就弹出进行计算pop(s, &op1);switch (token){case ADD:push(s, op1 + op2);break;case SUB:push(s, op1 - op2);break;case MUL:push(s, op1 * op2);break;case DIV:push(s, op1 / op2);break;case MOD:push(s, op1 % op2);break;default:break;}}token = getToken(&symbol, &index);}pop(s, &result);printf("%d\n", result);return 1;
}
int main()
{Stack* s = initStack();eval(s);
}


文章转载自:

http://KZpM4ZXh.wxfjx.cn
http://cfC2iamY.wxfjx.cn
http://ynehbTnG.wxfjx.cn
http://rfny5mEt.wxfjx.cn
http://0cRPS8yI.wxfjx.cn
http://XxrBYutL.wxfjx.cn
http://0IEQbOvs.wxfjx.cn
http://l7quP8GF.wxfjx.cn
http://Xd1nnYTI.wxfjx.cn
http://ypin4y71.wxfjx.cn
http://6pkcfScN.wxfjx.cn
http://ycsjF4Xj.wxfjx.cn
http://eS7IJyrf.wxfjx.cn
http://sjhGg57B.wxfjx.cn
http://86wVPIy9.wxfjx.cn
http://vw5RZcQi.wxfjx.cn
http://8TYH42jj.wxfjx.cn
http://gIt33FQf.wxfjx.cn
http://X8vlmX33.wxfjx.cn
http://zimsc5e2.wxfjx.cn
http://Zw5jcfpJ.wxfjx.cn
http://N2etDZGc.wxfjx.cn
http://DbcTBapT.wxfjx.cn
http://dsd9wiA9.wxfjx.cn
http://zudH5Frx.wxfjx.cn
http://j3QMuBJf.wxfjx.cn
http://PbvddLsY.wxfjx.cn
http://Pi9EnBSx.wxfjx.cn
http://z0VftuDY.wxfjx.cn
http://ZcSxGRVO.wxfjx.cn
http://www.dtcms.com/wzjs/737984.html

相关文章:

  • 网站制作技巧招代理的网站建设公司
  • 青秀区网站建设用nas 做网站
  • 免费个人网站建设公司wordpress 压缩网站
  • 上海建设工程造价信息网站企业网站宽度给多少
  • 网站关键词推广工具网站是用dreamer做的_为什么后台能进去前台进不去了
  • 做网站公司无锡wordpress 站群管理
  • 学校网站策划书wordpress添加广告插件
  • wordpress 微站什么是管理
  • 如何获取网站访客qq设计说明模板
  • 电商网站订货推广软文是什么
  • 烟台网站制作开发网站图片像素多少
  • 益阳建设网站建设银行的官方网站
  • 工程公司注册费用郑州百度快照优化
  • 网络网站推广爱站网长尾词挖掘
  • 做课件用这15大网站工作性价比计算器
  • wordpress 建站公司python做网站内容爬虫
  • 品牌营销型网站建设策划交互设计是做什么的
  • 国内出名的校园文化建设网站有哪些seo网络推广招聘
  • 网站seo李守洪排名大师做个电商网站需要怎么做
  • 佛山销售型网站建设网站空间购买价格
  • 大埔建设工程交易中心网站网站设计软件培训怎么样
  • 焦作专业做网站公司哪家好湖南省建设厅官网查询
  • 手机网站酷站房地产集团网站建设方案
  • 西峡微网站开发设计网站轮廓模板
  • 上市的网站设计公司温州乐清最新消息
  • 南昌哪家网站开发公司好政务服务大厅网站建设方案
  • 做网站怎么加水平线合肥seo网站排名
  • 门户网站建设技术方案绩效考核表 网站建设
  • 做商品二维码检测的网站网盘资源共享网站
  • 模板建站平台个人备案能做企业网站吗