- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
/*
表达式求值,输入一个表达式,如 1+2*3#,程序可计算出结果为 7 支持以下符号:
+ - * / ( ) ^ .
可以计算整数、小数
其中^表示次方,2^5 表示 2 的 5 次方
*/
/*头文件*/
#include stdio.h
#include malloc.h
#include string.h
#include math.h
#include stdlib.h
/*宏定义*/
#define INIT_STACK_SIZE 100
#define SET_NUM 8
#define N 100
/*字符优先级表*/
unsigned char prior[SET_NUM][SET_NUM] =
{
/* + - * / ( ) # ^ */
/*+*/, , , , , , , ,
/*-*/, , , , , , , ,
/***/, , , , , , , ,
/*/*/, , , , , , , ,
/*(*/, , , , , =, , ,
/*)*/, , , , , , , ,
/*#*/, , , , , , =, ,
/*^*/, , , , , , ,
};
unsigned char priorSet[SET_NUM] = {+, -, *, /, (, ), #, ^};
/*结构体定义,这是用来存放字符的栈*/
typedef struct
{
char *base;
char *top;
int stacksize;
} SqStackC;
/*结构体定义,这是用来存放数字的栈*/
typedef struct
{
double *base;
double *top;
int stacksize;
} SqStackN;
void initStackN(SqStackN );
void initStackC(SqStackC );
void pushN(SqStackN , double);
void pushC(SqStackN , double);
void popN(SqStackN , double );
void popC(SqStackN , double );
double calculate(double, char, double);
int findInSet(char);
char compare(char, char);
void getSolution();
/*主函数*/
void main()
{
getSolution();
}
/*初始化数字栈*/
void initStackN(SqStackN S)
{
S.base = (double*) malloc(INIT_STACK_SIZE * sizeof(double)); S.top = S.base;
S.stacksize = INIT_STACK_SIZE;
}
/*初始化字符栈*/
void initStackC(SqStackC S)
{
S.base = (char*) malloc(INIT_STACK_SIZE * sizeof(char)); S.top = S.base;
S.stacksize = INIT_STACK_SIZE;
}
/*向数字栈中存放数字*/
void pushN(SqStackN S, double x)
{
if (S.top-S.base = S.stacksize)
return;
*(S.top++) = x;
}
/*向字符栈中存放字符*/
void pushC(SqStackC S, char x)
{
if (S.top - S.base = S.stacksize)
return;
*(S.top++) = x;
}
/*从数字栈中取出数字*/
void popN(SqStackN S, double x)
{
if (S.top==S.base)
return;
x = *(--S.top);
}
/*从字符栈中取出字符*/
void popC(SqStackC S, char x)
{
if (S.top == S.base)
return;
x = *(--S.top);
}
/*这个函数返回 a operation b 的值。假如 operation 为+,则返回 a+b 的值*/ double calculate(double a, char operation, double b)
{
/*判断 operation,返回对应的计算结果*/
switch (operation) {
case +:
return a + b;
case -:
return b - a;
case *:
return a * b;
您可能关注的文档
- bpmf教学设计第一课时.docx
- Bosch博世电动吹风机使用说明.docx
- Braden压疮因素风险评估报告表.docx
- BRW400/31.5乳化液泵使用说明书.docx
- Buck变换器的设计与仿真.docx
- BUCK电路学习笔记.docx
- BUG生命周期及优先级、严重级划分.docx
- BUSYBOX编译错误提示及解决办法集绵.docx
- Bugfree常用操作说明.docx
- bug等级及优先级定义.docx
- 2025浙江温州市公用事业发展集团有限公司面向高校招聘工作人考前自测高频考点模拟试题最新.docx
- 2025年蓬安县财政局下属单位招聘备考题库附答案.docx
- 广安市农业农村局2025年公开遴选市动物卫生监督所工作人员备考题库附答案.docx
- 南昌市劳动保障事务代理中心招聘3名劳务派遣驾驶员参考题库附答案.docx
- 2025浙江绍兴市新昌县机关事业单位招用编外聘用人员36人备考题库最新.docx
- 浙江国企招聘-2025嘉兴海盐县城市投资集团有限公司招聘7人笔试备考试题附答案.docx
- 长沙银行2026校园招聘备考题库最新.docx
- 2026年度中国地震局事业单位公开招聘备考题库附答案.docx
- 2025福建省晋江圳源环境科技有限责任公司招聘6人模拟试卷附答案.docx
- 浙江国企招聘-2025温州平阳县城发集团下属房开公司招聘5人公笔试备考试题附答案.docx
最近下载
- DB3204T1024 污水排入城镇污水管网排放口设置技术规范.pdf VIP
- 保安意识和保安职责(含Z07Z08)推荐.docx VIP
- gdc数字电影服务器ftp功能.pdf VIP
- 医疗设备智能化在心血管疾病治疗中的应用与效果评估教学研究课题报告.docx
- 《循环神经网络》PPT课件.pptx VIP
- 生成式AI在CV算法测试中的创新实践-2025研发效能最佳实践.pdf VIP
- 仪器制造技术名词解释.doc VIP
- 2025福建福州市江南智慧城市建设运营有限公司招聘10人备考题库附答案解析.docx VIP
- 高中物理选择性必修2教材习题答案.docx VIP
- 大学生职业生涯规划大赛获奖作品7206.pdf VIP
原创力文档


文档评论(0)