LR(0) 构造DFA

代码:

package analyzer;

import java.util.Scanner;

public class Analyze {
	
	static Scanner in = new Scanner(System.in);
	static String endChar,misendChar;
	static String[] grammer;
	static String[] addgrammer;
	static String[][] dfa;
	
	public static void main(String[] args) {
		
		int num;
		int addnum = 2;
		
		System.out.println("请输入终结符:");
		endChar = in.next();
		System.out.println("请输入非终结符(请使用S外的其它字符):");
		misendChar = in.next();
		System.out.println("请输入文法个数:");
		num = in.nextInt();
		num +=1;
		
		grammer = new String[num];		
		
		System.out.println("请输入文法:");
		for(int i=1; i<num; i++) {
			System.out.print("第"+i+"个:");
			grammer[i] = in.next();	
			addnum += grammer[i].length()-2;
		}
		
		grammer[0] = "S->"+String.valueOf(grammer[1].charAt(0));
		addgrammer = new String[addnum];
		
		for(int j=0,r=0;j<num;j++) {
			for(int k=0,t=3;k<grammer[j].length()-2;k++) {
				StringBuffer sbf = new StringBuffer(grammer[j]);
				addgrammer[r] = new String(sbf.insert(t, ".")); 
				t+=1;
				r++;
			}			
		}
		dfa =new String[addnum][addnum];
		
		for(int j=0,r=0;j<addnum;j++) {
			if(addgrammer[j].equals("out")==false) {				
				findChild(addgrammer[j],r,0);
				r++;
			}		
		}	
		
		
		for(int j=0;j<dfa.length;j++) {
			if(dfa[j][0]!=null) {
				System.out.println("******I["+j+"]******");
				for(int i=0;i<dfa[j].length;i++) {				
					if(dfa[j][i]!=null)
					System.out.println(dfa[j][i]);
				}	
			}
		}
	
	}

	private static void findChild(String s, int t, int k) {	
		if(k==0) {
			dfa[t][k] = s;	
		}		
		int index = s.indexOf(".");
		if(index<s.length()-1) {
			String st = String.valueOf(s.charAt(index+1));
			if(misendChar.contains(st)) {
				String str = st+"->.";
				for(int i=0;i<addgrammer.length;i++) {
					if (addgrammer[i].contains(str)) {
						k++;
						dfa[t][k] = addgrammer[i];
						addgrammer[i] = "out";
						findChild(dfa[t][k],t,k);
					}					
				}
			}
		}
	}
	
	

}

图片:

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值