资源简介
用于编译原理课设 或小作业 很有用的主要是三元式四元式 逆波兰式
代码片段和文件信息
class Four {
public Four(String text) {
sb = new StringBuffer();
this.text = text;
str = this.text.toCharArray();
toBeSolute = str;
}
String getResult () {
return sb.toString() ;
}
StringBuffer getStringBuffer() {
return sb;
}
public static final int MAX = 100;
StringBuffer sb;
int m = 0 sum = 0;// sum用于计算运算符的个数
// m用于标记输入表达式中字符的个数
String text = new String(““);
char JG = ‘A‘;
char[] toBeSolute;
char[] str = new char[MAX];// 用于存输入表达式
int token = 0;// 左括号的标志
/** *********用于更改计算后数组中的值************* */
void change(int e) {
int f = e + 2;
char ch = str[f];
if (ch >= ‘A‘ && ch <= ‘Z‘) {
for (int l = 0; l < str.length; l++) {
if (str[l] == ch)
str[l] = JG;
}
}
if (str[e] >= ‘A‘ && str[e] <= ‘Z‘) {
for (int i = 0; i < m; i++) {
if (str[i] == str[e])
str[i] = JG;
}
}
}
void chengchuchuli(int i int m) {
i++;
for (; i <= m - 1; i++)// 处理乘除运算
{
if (str[i] == ‘*‘ || str[i] == ‘/‘) {
System.out.println(“(“+(char)(JG+32)+“)“+“(“ + str[i] + “ “ + str[i - 1] + “ “
+ str[i + 1] + “ “ + JG + “)“);
sb.append(“(“+(char)(JG+32)+“)“+“(“ + str[i] + “ “ + str[i - 1] + “ “
+ str[i + 1] + “ “ + JG + “)“+“\n“);
change(i - 1);
str[i - 1] = str[i] = str[i + 1] = JG;
sum--;
JG++;
}
}
}
void jiajianchuli(int j int m) {
j++;
for (; j <= m - 1; j++)// 处理加减运算
{
if (str[j] == ‘+‘ || str[j] == ‘-‘) {
System.out.println(“(“+(char)(JG+32)+“)“+“(“ + str[j] + “ “ + str[j - 1] + “ “
+ str[j + 1] + “ “ + JG + “)“);
sb.append(“(“+(char)(JG+32)+“)“+“(“ + str[j] + “ “ + str[j - 1] + “ “
+ str[j + 1] + “ “ + JG + “)“+“\n“);
change(j - 1);
str[j - 1] = str[j] = str[j + 1] = JG;
sum--;
JG++;
}
}
}
/* 扫描一遍从文件中读入表达式 */
void scan() {
int[] p = new int[MAX];
char ch = ‘a‘;
int c = -1 q = 0;
for (int i = 0; i < toBeSolute.length; i++) {
ch = toBeSolute[i];
str[m++] = ch;
if (ch == ‘=‘ || ch == ‘+‘ || ch == ‘-‘ || ch == ‘*‘ || ch == ‘/‘)
sum++;
else if (ch == ‘(‘) {
p[++c] = m - 1;
} else if (ch == ‘)‘) {
q = m - 1;
chengchuchuli(p[c] q);// 从左括号处理到又括号
jiajianchuli(p[c] q);
JG--;
str[p[c]] = str[m - 1] = JG;
c--;
JG++;
}
}
}
/* 对表达是进行处理并输出部分四元式 */
void siyuanshi() {
for (int i = 0; i <= m - 1; i++)// 处理乘除运算
{
if (str[i] == ‘*‘ || str[i] == ‘/‘) {
System.out.println(“(“+(char)(JG+32)+“)“+“(“ + str[i] + “ “ + str[i - 1] + “ “
+ str[i + 1] + “ “ + JG + “)“);
sb.append(“(“+(char)(JG+32)+“)“+“(“ + str[i] + “ “ + str[i - 1] + “ “
+ str[i + 1] + “ “ + JG + “)“+“\n“);
change(i - 1);
str[i - 1] = str[i] = str[i + 1] = JG;
sum--;
JG++;
}
}
for (int j = 0; j <= m - 1; j++)// 处理加减运算
{
if (str[j] == ‘+
属性 大小 日期 时间 名称
----------- --------- ---------- ----- ----
文件 390 2008-09-13 09:18 ZhongJianDaiMa\.project
文件 226 2008-09-13 09:18 ZhongJianDaiMa\.classpath
文件 4510 2008-09-21 15:20 ZhongJianDaiMa\Four.java
文件 3686 2008-09-21 15:44 ZhongJianDaiMa\JMain.java
文件 4297 2008-09-21 15:20 ZhongJianDaiMa\Three.java
文件 2213 2008-09-21 15:20 ZhongJianDaiMa\ZJMain.java
文件 4324 2008-09-28 08:53 ZhongJianDaiMa\Four.class
文件 600 2008-09-28 08:53 ZhongJianDaiMa\JMain$5.class
文件 578 2008-09-28 08:53 ZhongJianDaiMa\JMain$1.class
文件 3355 2008-09-28 08:53 ZhongJianDaiMa\JMain.class
文件 1021 2008-09-28 08:53 ZhongJianDaiMa\JMain$3.class
文件 1063 2008-09-28 08:53 ZhongJianDaiMa\JMain$4.class
文件 1353 2008-09-28 08:53 ZhongJianDaiMa\JMain$2.class
文件 4191 2008-09-28 08:53 ZhongJianDaiMa\Three.class
文件 2056 2008-09-28 08:53 ZhongJianDaiMa\ZJMain.class
目录 0 2008-09-13 09:18 ZhongJianDaiMa
----------- --------- ---------- ----- ----
33863 16
- 上一篇:飞机票管理系统Java
- 下一篇:传智播客黑马班Java企业实战项目.txt
相关资源
- mysql数据处理,java用户登录处理
- 法律咨询信息系统(java+jsp+sqlserver)
- Java快速开发平台源码(renren-fast)
- 锐聘学院QST青软JavaWeb十二个打包
- 3.3.6微信支付JAVA版demo
- javaweb网上购物系统源码(附数据库脚
- javaweb校园宿舍系统(附数据库脚本)
- JavaWeb书城项目(附数据库脚本)
- 基于JAVA_JSP电子书系统(源码+数据库
- Java网络编程知识点总结.xmind
- 一站式Java网络编程 BIO-NIO-AIO资料源码
- jsp讲解
- 基于SSH框架的JavaWeb项目—人员信息管
- javaweb实现的邮件收发系统(附数据库
- Java 仿QQ(附客户端以及服务端源码)
- Java TCP IP Socket
- java定时发送邮件(基于quartz)
- Java Swing开发的《星际争霸》游戏
- java+数据库商品交易管理系统(附数据
- 使用java语言编译一个计算器
- java swing工资管理系统(源码+数据库
- JAVALibrary
- 微信企业号回调模式Java版
- 顺丰丰桥接口开发详细教程源码含下
- Java博客概要设计文档
- 药品进销存管理系统(论文范文_JSP
- 奖学金管理系统java+jsp+mysql
- 毕设参考——基于java酒店管理
- Java写的一个简单的字体更改程序
- java8学习教程之lambda表达式的使用方法
评论
共有 条评论