资源简介
用于编译原理课设 或小作业 很有用的主要是三元式四元式 逆波兰式

代码片段和文件信息
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
相关资源
- jsonarray所必需的6个jar包.rar
- 三角网构TIN生成算法,Java语言实现
- java代码编写将excel数据导入到mysql数据
- Java写的cmm词法分析器源代码及javacc学
- JAVA JSP公司财务管理系统 源代码 论文
- JSP+MYSQL旅行社管理信息系统
- 推荐算法的JAVA实现
- 基于Java的酒店管理系统源码(毕业设
- java-图片识别 图片比较
- android毕业设计
- java23种设计模式+23个实例demo
- java Socket发送/接受报文
- JAVA828436
- java界面美化 提供多套皮肤直接使用
- 在线聊天系统(java代码)
- 基于Java的图书管理系统807185
- java中实现将页面数据导入Excel中
- java 企业销售管理系统
- java做的聊天系统(包括正规课程设计
- Java编写的qq聊天室
- 商店商品管理系统 JAVA写的 有界面
- JAVA开发聊天室程序
- 在linux系统下用java执行系统命令实例
- java期末考试试题两套(答案) 选择(
- JAVA3D编程示例(建模、交互)
- Java 文件加密传输
- java做的房产管理系统
- 基于jsp的bbs论坛 非常详细
- [免费]java实现有障碍物的贪吃蛇游戏
- java Servlet投票实例
评论
共有 条评论