根据优先关系矩阵使用逐次加一法构造优先函数(Java)

若已知运算符之间的优先关系,可按如下步骤构造优先函数:

1、对每个运算符a(包括#在内)令f(a)=g(a)=1

2、如果a⋗b且f(a)<=g(b)令f(a)=g(b)+1

3、如果a⋖b且f(a)>=g(b)令g(b)= f(a)+1

4、如果a≐b而f(a) ≠g(b),令min{f(a),g(b)}=max{f(a),g(b)}

5、重复2~4,直到过程收敛。如果重复过程中有一个值大于2n,则表明不存在算符优先函数。

 

import java.util.Scanner;

/**
 * Created by redli on 2017/5/2.
 *
 * 样例输入1
 * --------------------------------------------------
 请输入终结符(输入#号结束):
 +*()i#
 请输入关系矩阵(#号结束):
 ><<><>><><<<<+<>>!>!>>!>!#
 -----------------------------------------------------
 * 样例输入2
 * --------------------------------------------------
 请输入终结符(输入#号结束):
 abcd#
 请输入关系矩阵(#号结束):
 !!>>!!>!<=<!=!=!#
 -----------------------------------------------------
 */
public class Floyd {
    public static Scanner in = new Scanner(System.in);
    public static StringBuffer terminal = new StringBuffer();
    public static StringBuffer matrix = new StringBuffer();
    public  static void main(String args[]){
        //输入
        Input input = new Input();
        input.inputTerminal();
        input.inputMatrix();

        //优先函数
        PriorityFunction priority_function = new PriorityFunction();
        priority_function.makePriorityFunction();
        priority_function.createPriorityFunction();
        priority_function.outPriorityFunction();
    }

    private static class Input{
        //输入终结符
        public void inputTerminal(){
            System.out.println("请输入终结符(输入#号结束):");
            String str = in.next();
            while(!str.equals("#")){
                if(str.substring(str.length()-1).equals("#")){
                    terminal.append(str.substring(0,str.length()-1));
                    str = "#";
                } else{
                    terminal.append(str);
                    str = in.next();
                }
            }
        }

        /*
        * 输入关系矩阵
        * 输入>,<,=,!(表示为空)
        * */
        public void inputMatrix(){
            System.out.println("请输入关系矩阵(#号结束):");
            String str = in.next();
            while(!(str.equals("#"))){
                if(!(str.substring(str.length()-1).equals("#"))){
                    matrix.append(str);
                    str = in.next();
                } else{
                    matrix.append(str.substring(0,str.length()-1));
                    str = "#";
                }
            }
        }
    }

    /*
    * 优先函数处理类
    * */
    private static class PriorityFunction{
        int num = terminal.length();
        int [][] arr = new int[2][num];
        /*
        * 构造优先函数,赋初值1
        * */
        public void makePriorityFunction(){
            for(int i=0; i<2; i++){
                for(int j=0;j<num;j++){
                    arr[i][j] = 1;
                }
            }
        }

        /*
        *
        * 生成优先函数
         *
         *  */
        public void createPriorityFunction(){
            int k=1;
            int terLength = terminal.length();
            while(k!=0){
                k = 0;
                for(int i=0; i<terminal.length();i++){
                    for(int j=0; j<terminal.length(); j++){
                        if(Character.toString(matrix.charAt(i*terLength+j)).equals(">") && arr[0][i]<=arr[1][j]){
                            arr[0][i]=arr[1][j]+1;
                            k=1;
                        } else if(Character.toString(matrix.charAt(i*terLength+j)).equals("<") && arr[0][i]>=arr[1][j]){
                            arr[1][j]=arr[0][i]+1;
                            k=1;
                        }
                    }
                }
            }
        }

        /*
        * 输出优先函数
        * */
        public void outPriorityFunction(){
            for(int k=0; k<terminal.length(); k++){
                System.out.print(terminal.charAt(k)+" ");
            }
            System.out.println();
            for(int i=0; i<2; i++){
                for(int j=0; j<terminal.length();j++){
                    System.out.print(arr[i][j]+" ");
                }
                System.out.print("\n");
            }
        }
    }
}

 

 

 

 

 

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
算符优先分析法C是一种用于语法分析的方法,它基于算符优先关系来进行分析和判断。算符优先分析法C的主要目的是确定输入的表达式字符串是否符合给定的文法规则。 在算符优先分析法C中,首先需要定义一个算符优先关系表,该表用于存储各种操作符之间的优先关系。然后,需要对给定的输入表达式进行预处理,将其转化为一个带有标识符和操作符的串。 接下来,通过扫描输入串,根据算符优先关系表来决定移进、规约或接受的操作。具体过程如下: 1. 初始化两个栈:一个用于存储操作符(operStack),一个用于存储标识符(identStack)。 2. 将输入表达式的结束标志符号(#)放入operStack。 3. 将输入表达式的第一个字符读入并放入identStack。 4. 重复以下步骤直到识别到结束标志符号: a. 如果当前操作符为“<”,则将其压入operStack。 b. 如果当前操作符为“>”,则根据相应规则不断进行规约,直到无法继续规约为止。 c. 如果当前操作符为“=”,则移除operStack的栈顶操作符和identStack的栈顶标识符。 5. 如果在规约过程中出现错误或者无法识别输入串,则分析过程失败。 6. 如果分析过程顺利完成,并且identStack中只剩下一个标识符且operStack中只剩下结束标志符号,则分析过程成功。 通过算符优先分析法C,我们可以判断一个给定的表达式是否符合文法规则,并且可以在分析过程中检测到错误。它是一种高效而可靠的语法分析方法,在编译器的设计和实现中得到了广泛应用。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值