[开源程序]要弄表达式运算,先来学习编译原理~
caoyuan96422010/10/10软件综合 IP:安徽
现在又觉得原来那个求导程序有点矬了。。。

主要是读入部分比较恶心,

数据结构不够好,

造成化简困难


昨天借来《编译原理》(龙书)
仔细钻研第一章之后深有感触~
遂择吉日开发此程序~

今天调试了一上午,终于弄懂了~

就是编译器的原理

这个程序主要是负责词法分析的(Parser)

用的结构也很简单,就是函数互相嵌套调用

class Parser{
private:
string lookfd;
    stringstream sin;
public:
bool expr();
bool term();
bool factor();
bool number();
bool identifier();
//bool letter();
//bool digit();
bool match(const string&);
bool get_token();
//void put_back();
bool funcname();
public:
void ClearStringStream(){XXXXXXear();}
void SetStringStream(const string& s){sin<<s;}
const string & GetStringStream()const {XXXXXXr();}
};

类Parser用于词法分析,其中的lookfd是读入的单词(向前看),sin是输入流,尚未使用
expr()处理整个表达式
term()处理初等项
factor()处理每一个因子
number、funcname、identifier之类的都是基础的东西
用语言描述如下:


剩下的事情就是编程序了。。。

程序不长,还可以顺便输出表达式的后缀表达式


attachment icon Parser.rar 4.18MB RAR 19次下载
来自:计算机科学 / 软件综合
4
已屏蔽 原因:{{ notice.reason }}已屏蔽
{{notice.noticeContent}}
~~空空如也
renmin
13年6个月前 IP:未同步
275122
支持。。。。。。。。。
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
cjboy2008
13年5个月前 IP:未同步
277658
词法分析器似乎叫Lexer....
Parser似乎是语法分析器~
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论
caoyuan9642作者
13年5个月前 IP:未同步
277664
当时我还是初级阶段。。。
后来重新弄了个类C编译器前端就全会了
引用
评论
加载评论中,请稍候...
200字以内,仅用于支线交流,主线讨论请采用回复功能。
折叠评论

想参与大家的讨论?现在就 登录 或者 注册

所属专业
上级专业
同级专业
caoyuan9642
学者 笔友
文章
49
回复
810
学术分
4
2009/05/06注册,8年0个月前活动
暂无简介
主体类型:个人
所属领域:无
认证方式:邮箱
IP归属地:未同步
文件下载
加载中...
{{errorInfo}}
{{downloadWarning}}
你在 {{downloadTime}} 下载过当前文件。
文件名称:{{resource.defaultFile.name}}
下载次数:{{resource.hits}}
上传用户:{{uploader.username}}
所需积分:{{costScores}},{{holdScores}}下载当前附件免费{{description}}
积分不足,去充值
文件已丢失

当前账号的附件下载数量限制如下:
时段 个数
{{f.startingTime}}点 - {{f.endTime}}点 {{f.fileCount}}
视频暂不能访问,请登录试试
仅供内部学术交流或培训使用,请先保存到本地。本内容不代表科创观点,未经原作者同意,请勿转载。
音频暂不能访问,请登录试试
支持的图片格式:jpg, jpeg, png
插入公式
评论控制
加载中...
文号:{{pid}}
投诉或举报
加载中...
{{tip}}
请选择违规类型:
{{reason.type}}

空空如也

加载中...
详情
详情
推送到专栏从专栏移除
设为匿名取消匿名
查看作者
回复
只看作者
加入收藏取消收藏
收藏
取消收藏
折叠回复
置顶取消置顶
评学术分
鼓励
设为精选取消精选
管理提醒
编辑
通过审核
评论控制
退修或删除
历史版本
违规记录
投诉或举报
加入黑名单移除黑名单
查看IP
{{format('YYYY/MM/DD HH:mm:ss', toc)}}