资源简介
实现一个关于表达式的LR语法分析程序 识别用户输入的包含变量与整数的混合算术表达式(不包含减法与除法运算)
文法如下:
0 S E
1 E E+E
2 E E E
3 E E
4 E i
编程运用上述LR分析表 识别从键盘输入的算术表达式 ">实现一个关于表达式的LR语法分析程序 识别用户输入的包含变量与整数的混合算术表达式(不包含减法与除法运算)
文法如下:
0 S E
1 E E+E
2 E E E
3 E E
4 E i
编程运用上述LR分析表 识别从键盘输入的算术表达 [更多]
代码片段和文件信息
import java.util.ArrayList;
import java.util.Scanner;
public class test3 {
static int [][] E_LR = {{-1-12-13-11}
{45-1-1-10-1}
{-1-12-13-16}
{104104-1104-1104-1}
{-1-12-13-17}
{-1-12-13-18}
{45-19-1-1-1}
{1015-1101-1101-1}
{102102-1102-1102-1}
{103103-1103-1103-1}};
static String str = “+*()i#E“;
static ArrayList state = new ArrayList();
static ArrayList fuhao = new ArrayList();
static ArrayList data = new ArrayList();
static ArrayList check = new ArrayList();
static int max = data.size();
static int table = 0;
static String dutou = ““;
static String string = ““;
static int n = 0;
public static void main(String[] args) {
Scanner input = new Scanner(System.in);
String str = input.nextLine();
string = str;
str += “ #“;
str = str.replace(“(“ “ ( “);
str = str.replace(“)“ “ ) “);
str = str.replace(“+“ “ + “);
str = str.replace(“*“ “ * “);
str = str.replace(“#“ “ # “);
String s = ““;
for(int i=0;i if(str.charAt(i) != ‘ ‘){
s += str.charAt(i);
}else{
data.add(s);
s=““;
continue;
}
}
deleteBlack(data);
for(int i=0;i if(!data.get(i).equals(“(“)&&!data.get(i).equals(“)“)&&!data.get(i).equals(“+“)&&!data.get(i).equals(“*“)&&!data.get(i).equals(“#“)){
if(judge1(data.get(i))||judge2(data.get(i))){
data.set(i “i“);
}else{
System.out.println(“标识符或数字“+data.get(i)+“有误!“);
System.exit(0);
}
}
}
state.add(“0“);
fuhao.add(“#“);
dutou = data.get(n);
if(!dutou.equals(“E“)&&!dutou.equals(“(“)&&!dutou.equals(“i“)){
System.out.println(“表达式无第一个操作数“);
System.exit(0);
}
while(true){
int x = getindex1();//获取state栈顶元素在表中位置
int y = getindex2(dutou);//获取读头在表中位置位置
table = E_LR[x][y];
if(table == 0){
System.out.println(“表达式正确,分析成功“);
System.exit(0);
}else if(table<100){
fuhao.add(dutou);
check.add(dutou);
state.add(String.valueOf(table));
n++;
dutou = data.get(n);
switch(table){
case 0:
case 2:
case 4:
case 5:
if(!dutou.equals(“(“)&&!dutou.equals(“i“)&&!dutou.equals(“E“)){
System.out.println(“缺少操作数“);
System.exit(0);
}
break;
case 1:
if(!dutou.equals(“+“)&&!dutou.equals(“*“)&&!dutou.equals(“#“)){
System.out.println(“错误1“);
System.exit(0);
}
break;
case 6:
if(!dutou.equals(“+“)&&!dutou.equals(“*“)&&!dutou.equals(“)“)){
System.out.println(“错误6“);
System.exit(0);
}
break;
case 3:
case 7:
case 8:
case 9:
if(!dutou.equals(“+
相关资源
- 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表达式的使用方法
评论
共有 条评论