资源简介
用c语言实现表达式计算(加减乘除),(3-1)*(4+6)/5#表达式文件读取,堆栈实现。
char Operate(char a,char th,char b)
{
double lop,rop;
lop=number[a-'a'];
rop=number[b-'a'];
switch(th)
{
case'+':
number[a-'a']=lop+rop;
break;
case'-':
number[a-'a']=lop-rop;
break;
case'*':
number[a-'a']=lop*rop;
break;
case'/':
number[a-'a']=lop/rop;
break;
}
return a;
}
代码片段和文件信息
#include“stdio.h“
#include“string.h“
#include“conio.h“
#include “stdlib.h“
#include “Stack.h“
char exp[100];
double number[30];
//读取表达式
void input()
{
int ijkl;
char chtemp[30]num=‘a‘;
char str[50];
FILE *fp;
fp=fopen(“exp.txt““r“);
if(!fp)
{
printf(“文件打开失败!\n“);
return;
}
i=0;j=0;k=0;l=0;
while((ch=fgetc(fp))!=‘#‘)
{
str[l++]=ch;
if((ch>=‘0‘&&ch<=‘9‘)||ch==‘.‘)
{
j=0;
while((ch>=‘0‘&&ch<=‘9‘)||ch==‘.‘)
{
temp[j]=ch;
ch=fgetc(fp);
str[l++]=ch;
j++;
}
temp[j]=‘\0‘;
number[k]=atof(temp);
k++;
exp[i]=num;
num+=1;
i++;
}
exp[i]=ch;
if(ch==‘#‘) break;
i++;
}
str[l]=‘\0‘;
if(str[l-1]==‘#‘) str[l-1]=‘\0‘;
exp[i]=ch;
i++;
exp[i]=‘\0‘;
fclose(fp);
printf(“表达式为:\n“);
printf(“%s\n“str);
}
//判断是否为运算符
int In(char ch char *optr)
{
int i=0;
while(optr[i]!=‘\0‘)
{
if( optr[i]==ch)
return 1;
i++;
}
return 0;
}
//返回运算符优先级
char Precede(char optr1char optr2)
{
int i=0;
int optr_ioptr_j;
while(op[i]!=‘\0‘)
{
if(op[i]==optr1)
{
optr_i=i;
break;
}
i++;
}
i=0;
while(op[i]!=‘\0‘)
{
if(op[i]==optr2)
{
optr_j=i;
break;
}
i++;
}
return Priav[optr_i][optr_j];
}
char Operate(char achar thchar b)
{
double loprop;
lop=number[a-‘a‘];
rop=number[b-‘a‘];
switch(th)
{
case‘+‘:
number[a-‘a‘]=lop+rop;
break;
case‘-‘:
number[a-‘a‘]=lop-rop;
break;
case‘*‘:
number[a-‘a‘]=lop*rop;
break;
case‘/‘:
number[a-‘a‘]=lop/rop;
break;
}
return a;
}
//表达式求值
double Evaluateexpression()
{
SqStack OPTROPND;
int i=0;
char cxthetaab;
InitStack(&OPTR);
Push(&OPTR‘#‘);
InitStack(&OPND);
c=exp[i];
i++;
while(c!=‘#‘||GetTop(OPTR)!=‘#‘)
{
if(!In(cop))
{
Push(&OPNDc);
c=exp[i];
i++;
}
else
{
x=GetTop(OPTR);
switch(Precede(xc))
{
case‘<‘:
Push(&OPTRc);
c=exp[i];
i++;
break;
case‘=‘:
Pop(&OPTR&x);
c=exp[i];
i++;
break;
case‘>‘:
Pop(&OPTR&theta);
Pop(&OPND&b);
Pop(&OPND&a);
Push(&OPNDOperate(athetab));
break;
}
}
}
a=GetTop(OPND);
return number[a-‘a‘];
}
main()
{
double result;
input();
printf(“结果为:\n“);
result=Evaluateexpression();
printf(“%f\n“result);
getch();
}
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 2512 2009-06-17 12:02 桌面计算器\exp.c
文件 208980 2009-06-17 12:02 桌面计算器\exp.exe
文件 18 2009-05-16 21:52 桌面计算器\exp.txt
文件 14 2009-06-17 11:42 桌面计算器\exp1.txt
文件 919 2009-06-17 11:30 桌面计算器\Stack.h
目录 0 2009-06-18 11:03 桌面计算器
----------- --------- ---------- ----- ----
212443 6
相关资源
- C++中头文件与源文件的作用详解
- C语言代码高亮html输出工具
- 猜数字游戏 c语言代码
- C语言课程设计
- 数字电位器C语言程序
- CCS FFT c语言算法
- 使用C语言编写的病房管理系统
- 通信过程中的RS编译码程序(c语言)
- 计算机二级C语言上机填空,改错,编
- 用回溯法解决八皇后问题C语言实现
- 简易教务管理系统c语言开发文档
- 操作系统课设 读写者问题 c语言实现
- 小波变换算法 c语言版
- C流程图生成器,用C语言代码 生成C语
- 3des加密算法C语言实现
- 简单的C语言点对点聊天程序
- 单片机c语言源程序(51定时器 八个按
- 个人日常财务管理系统(C语言)
- c语言电子商务系统
- 小甲鱼C语言课件 源代码
- 将图片转换为C语言数组的程序
- C语言实现的一个内存泄漏检测程序
- DES加密算法C语言实现
- LINUX下命令行界面的C语言细胞游戏
- 用单片机控制蜂鸣器播放旋律程序(
- 学校超市选址问题(数据结构C语言版
- 电子时钟 有C语言程序,PROTEUS仿真图
- 尚观培训linux许巍老师关于c语言的课
- 算符优先语法分析器(C语言编写)
- 基于C语言的密码锁程序
评论
共有 条评论