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

运算表达式求值c代码(用栈实现)


author: hjjdebug
date: 2026年 01月 12日 星期一 14:27:03 CST
descrp: 运算表达式求值c代码(用栈实现)


文章目录

  • 1. 运算是计算机的强项
  • 2 字符串解析函数
  • 3. 代码说明:
  • 4. 代码

计算机与人的接口. 让计算机理解人的意图.
计算机最擅长固定的操作, 它的要素是存储数据,对数据运算.
人机的接口必须要按照一种规则, 规则应该是越简单越好, 但也要符合人的习惯,不能迁就计算机.
我们熟知的运算表达式求值无疑就是最基础的人机交互接口.
规则是先计算括号内的值, 乘除运算高于加减运算

1. 运算是计算机的强项

至于运算,非常简单. 一个函数就能搞定.
假定数值是int型

// 计算函数
int applyOp(int a, int b, char op) {
switch (op) {
case ‘+’: return a + b;
case ‘-’: return a - b;
case ‘*’: return a * b;
case ‘/’: return a / b;
}
return 0;
}

关键是如何调用到这个函数. 调用逻辑怎样写,这就是程序框架.
而且用户的输入是灵活的, 它可能输入任何表达式, 并不会是固定的.

2 字符串解析函数

如何应对不同的字符串?

这离不开字符串解析函数. 由于字符串并不是固定的,所以必须按照约定的规则进行.
把字符串一个字符一个字符的进行分析, 分析出词,形成token, 这叫词法分析.
由词根据前后关系解析出意义这叫句法分析. 这个解析的过程都在主框架中.
把字符串分析完了,结果也就出来了.

3. 代码说明:

实现了基本的四则运算(+ - * /)和括号优先级处理
使用两个栈分别存储操作数和操作符
支持多位数操作数和空格分隔符
通过优先级函数控制运算顺序
主函数实现命令行交互

核心: 用一个栈来存储数据,用一个栈来存储操作符号.
当发现满足运算条件时,执行运算.

4. 代码

$ cat main.c#include<stdio.h>// for printf#include<stdlib.h>// for exit,malloc,free#include<string.h>// for strchr, strlen#include<assert.h>// for assert// 优先级函数intprecedence(charop){if(op=='+'||op=='-')return1;if(op=='*'||op=='/')return2;return0;}// 操作数判断intisDigit(charc){return(c>='0'&&c<='9');}// 计算函数intcalculate(inta,intb,charop){switch(op){case'+':returna+b;case'-':returna-b;case'*':returna*b;case'/':returna/b;}return0;}#defineAPPLY_OPERATOR\assert(val_index>=2);\assert(op_index>=1);\intval2=values[val_index-1];\val_index--;\intval1=values[val_index-1];\val_index--;\charop=ops[op_index-1];\op_index--;\values[val_index++]=calculate(val1,val2,op);// 求值函数intevaluate(char*exp){inti;intlen=strlen(exp);if(len==0)return0;// 万一是空串int*values=malloc(len*sizeof(int));// 操作数栈char*ops=malloc(len*sizeof(char));// 操作符栈intval_index=0,op_index=0;for(i=0;i<len;i++){if(exp[i]==' ')continue;// 忽略空格if(isDigit(exp[i])){intval=0;while(i<len&&isDigit(exp[i])){val=(val*10)+(exp[i]-'0');i++;}values[val_index++]=val;i--;// 调整索引}elseif(exp[i]=='('){ops[op_index++]=exp[i];}elseif(exp[i]==')'){while(op_index>0&&ops[op_index-1]!='('){APPLY_OPERATOR;}if(op_index>0&&ops[op_index-1]=='('){op_index--;}}elseif(strchr("+-*/()",exp[i])==NULL){printf("错误: 非法字符 '%c'\n",exp[i]);exit(EXIT_FAILURE);}else{while(op_index>0&&precedence(ops[op_index-1])>=precedence(exp[i])){APPLY_OPERATOR;}ops[op_index++]=exp[i];}}while(op_index>0){APPLY_OPERATOR;}intresult=values[0];free(values);free(ops);returnresult;}intmain(intargc,char*argv[]){/* char buf[1000]; printf("请输入运算表达式: "); char *p=fgets(buf, sizeof(buf), stdin); assert(p!=NULL); buf[strcspn(buf, "\n")] = 0; // 去除换行符 int result = evaluate(buf); */if(argc!=2){printf("Usage: %s expression\n",argv[0]);printf("Example: %s \"1+2*3\"\n",argv[0]);exit(0);}intresult=evaluate(argv[1]);printf("结果: %d\n",result);return0;}
http://www.jsqmd.com/news/234519/

相关文章:

  • 图像分类新选择:万能分类器实测,云端GPU比本地快5倍
  • AI智能实体侦测服务核心优势解析|高精度NER+动态彩色高亮
  • 别只看不练!30+程序员2个月转行大模型,2w+offer经验全分享,收藏这篇就够了!
  • 万能分类器图像分类实战:云端GPU 10分钟出结果,3块钱玩整天
  • 如何高效部署多语言翻译模型?HY-MT1.5镜像快速上手
  • 避坑!AI分类器环境配置:为什么99%新手会失败
  • 大学生不要一边做一边怀疑
  • 视觉代理新体验|Qwen3-VL-WEBUI助力Dify平台实现GUI操作自动化
  • AI视觉新突破:MiDaS单目深度估计实战应用与性能评测
  • 高效多语言互译新选择|基于HY-MT1.5大模型镜像实战解析
  • AI分类竞赛夺冠秘籍:弹性GPU+万能分类器调优
  • AI分类模型解释性:万能分类器决策可视化云端工具
  • GoLand 2026年1月最新版 2025.3.1 安装、授权、使用说明
  • 串口转网口通信:基于C++与Qt库的实现之旅
  • 智能高亮+极速推理|AI智能实体侦测服务赋能信息抽取场景
  • 分类模型联邦学习:万能分类器分布式训练+GPU集群
  • 为什么无线充需要Qi认证?
  • Stable Diffusion+分类器联动教程:1小时1块玩转智能标注
  • 沐曦C500适配HY-MT1.5全过程|vLLM框架下高效推理实践
  • Windows OLE零点击RCE漏洞分析:CVE-2025-21298调查实战
  • 【WRF-VPRM WRF-GHG-Prepy工具】其五 背景场处理-初始/边界条件:CAMS-Inversion数据(函数解析)
  • airplay认证流程有哪些?
  • AI万能分类器5分钟上手:云端GPU开箱即用,新手指南
  • MiDaS部署教程:如何实现高效稳定的深度估计
  • 轻量高效翻译方案落地|HY-MT1.5-1.8B镜像在边缘设备的应用实践
  • 万能分类器持续学习:增量训练云端自动化方案
  • 探索口罩点焊机:大功率超声波20k与15k参数及相关资料解析
  • 支持33+5种语言互译|HY-MT1.5大模型镜像技术亮点揭秘
  • 解锁可控翻译新范式|HY-MT1.5支持术语干预与结构化输出
  • AirPlay 认证的完整资料清单、周期