




全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
实验四 中间代码生成一、 实验内容设计一个程序,该程序能够将形如 x = y op z 的简单赋值语句翻译为对应的四元式序列,其中 op 可为+、-、*、/等二元运算符。(可参考实验指导书P163 至 P164)。要求用JAVA语言编程。例如:若输入赋值语句 a = b + c,则输出如下四元式序列。二、 程序代码InToPost.JAVApackage zlf;import java.io.IOException;public class InToPost private Stack theStack; private String input; private String output = ; public InToPost(String in) input = in; int stackSize = input.length(); theStack = new Stack(stackSize); public String doTrans() for (int j = 0; j input.length(); j+) char ch = input.charAt(j); switch (ch) case +: case -: gotOper(ch, 1); break; case *: case /: gotOper(ch, 2); break; case (: theStack.push(ch); break; case ): gotParen(ch); break; default: output = output + ch; break; while (!theStack.isEmpty() output = output + theStack.pop(); / System.out.println(output); return output; public void gotOper(char opThis, int prec1) while (!theStack.isEmpty() char opTop = theStack.pop(); if (opTop = () theStack.push(opTop); break; else int prec2; if (opTop = + | opTop = -) prec2 = 1; else prec2 = 2; if (prec2 prec1) theStack.push(opTop); break; else output = output + opTop; theStack.push(opThis); public void gotParen(char ch) while (!theStack.isEmpty() char chx = theStack.pop(); if (chx = () break; else output = output + chx; class Stack private int maxSize; private char stackArray; private int top; public Stack(int max) maxSize = max; stackArray = new charmaxSize; top = -1; public void push(char j) stackArray+top = j; public char pop() return stackArraytop-; public char peek() return stackArraytop; public boolean isEmpty() return (top = -1); QuaternaryTypeOfAlgorithm.JAVApackage zlf;import java.awt.*;import java.awt.event.*;import javax.swing.*;import java.util.Stack;public class QuaternaryTypeOfAlgorithm extends JFrameprivate static Stack number = new Stack();private int n = 1;private JButton jbt = new JButton(生成);private JTextArea jta = new JTextArea();private JTextField jtf = new JTextField(A=B+C*D+E,20);private boolean hasError = false;public QuaternaryTypeOfAlgorithm()JPanel p1 = new JPanel();p1.add(jtf);p1.add(jbt);add(p1,BorderLayout.NORTH);add(new JScrollPane(jta),BorderLayout.CENTER);jbt.addActionListener(new ActionListener()public void actionPerformed(ActionEvent e)String equation = jtf.getText().trim();create(equation);number.clear();hasError = false;repaint(););public void create(String input)String output;InToPost theTrans = new InToPost(input);output = theTrans.doTrans(); tryfor(int i = 0 ; i output.length(); i+)String t = output.substring(i, i+1); if(t.equals(+) String n1 = number.pop(); String n2 = number.pop(); String n3 = T+n; n+; number.push(n3); jta.append(n-1+: (+,+n2+,+n1+,+n3+)+n); else if(t.equals(-) String n1 = number.pop(); String n3 = T+n; n+; number.push(n3); jta.append(n-1+: (-,+n1+,+ +,+n3+)+n); else if(t.equals(*) String n1 = number.pop(); String n2 = number.pop(); String n3 = T+n; n+; number.push(n3); jta.append(n-1+: (*,+n2+,+n1+,+n3+)+n); else if(t.equals(/) String n1 = number.pop(); String n2 = number.pop(); String n3 = T+n; n+; number.push(n3); jta.append(n-1+: (/,+n2+,+n1+,+n3+)+n); else if(t.matches(a-zA-Z0-9=) number.push(t); /System.out.println(number:+t); String last2 = number.pop();number.pop(); String last1 = number.pop(); n+; jta.append(n-1+: (=,+last2+, ,+last1+)+n+n+n);catch(Exception e)hasError = true;if(hasError|!number.empty()JOptionPane.showMessageDialog(null, 你输入的算式表达式有错!请重新输入); number.clear();public static void main(String args)QuaternaryTypeOfAlgorith
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025年乡村手工艺合作社法务岗位面试要点及模拟题解析
- 2025年中国电力建设集团招聘考试题库
- 2025年农村金融专业招聘考试模拟题集萃
- 抹灰工人安全培训内容课件
- 2025年临床医疗管理信息系统项目发展计划
- 2025年医用气体系统项目发展计划
- 福建省福州市2025-2026学年高三第一次质量检测数学试卷(含答案)
- 抗焦虑抑郁药物分类课件
- 2025年1月吕梁市贺昌中学第一学期高一期末学业水平测试必修一人教版2019
- 2024-2025学年广西柳州市三江侗族自治县人教版三年级下册期末考试数学试卷(含答案)
- 2025年中国物流集团国际物流事业部招聘面试经验及模拟题集
- 乡镇安全培训课件
- 2025四川省公安厅招聘辅警(448人)笔试参考题库附答案解析
- 中望CAD机械版使用手册
- 定额〔2025〕1号文-关于发布2018版电力建设工程概预算定额2024年度价格水平调整的通知
- 2024年9月28日安徽省地市级遴选笔试真题及解析
- 五运六气方剂
- 精益生产之自働化培训课件
- 施工现场岗位安全风险告知卡
- 腰椎穿刺术3PPT优秀课件
- 广州市小升初语文分析PPT学习教案
评论
0/150
提交评论