亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? parser.java

?? Java編寫的表達(dá)式計(jì)算器, 即可以像我們書寫表達(dá)式那樣直接輸入計(jì)算表達(dá)式, 程序自動進(jìn)行運(yùn)算, 支持加減乘除冪運(yùn)算以及判斷表達(dá)式如A?B C, 程序包含完整的Document和測試運(yùn)行環(huán)境
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
package parser;

import exceptions.*;
import java.util.*;
import java.math.*;
/**
 * 整個(gè)程序的parser,也是分析計(jì)算的核心所在
 * @author zouhao
 * @param opPos 這個(gè)字符串?dāng)?shù)組是用于定位查表的坐標(biāo)
 * @param table 這里是硬編碼的OPP表
 */
public class Parser {
    String opPos[] = {"(",")","f","-","^","m/d","+/-","cmp","!","&","|","?",":",",","Decimal","Boolean","$"};
        static int table[][] = {
/*      (   )   f   -   ^  m/d +/- cmp  !   &   |   ?   :   ,  id  T/F  $*/ 
/*(*/  {0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, -5,  0,  0,  0, -2},
/*)*/  {-3, 4, -3, -3,  4,  4,  4,  4, -3,  4,  4,  4,  4,  4, -3, -3,  4},
/*f*/  {0, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4, -4},
/*-*/  {0,  5,  0,  0,  5,  5,  5,  5, -3,  5,  5,  5,  5,  5,  0, -6,  5},
/*^*/  {0,  3,  0,  0,  0,  3,  3,  3, -3,  3,  3,  3,  3,  3,  0, -6,  3},
/*m/d*/{0,  3,  0,  0,  0,  3,  3,  3, -3,  3,  3,  3,  3,  3,  0, -6,  3},
/*+/-*/{0,  3,  0,  0,  0,  0,  3,  3, -3,  3,  3,  3,  3,  3,  0, -6,  3},
/*cmp*/{0,  6,  0,  0,  0,  0,  0,  6,  6,  6,  6,  6,  6,  6,  0, -6,  6},
/*!*/  {0,  8, -3,  0,  0,  0,  0,  0,  0,  8,  8,  8,  8, -6, -6,  0,  8},
/*&*/  {0,  7,  0,  0,  0,  0,  0,  0,  7,  7,  7,  7,  7,  7,  0,  0,  7},
/*|*/  {0,  7,  0,  0,  0,  0,  0,  0,  7,  0,  7,  7,  7,  7,  0,  0,  7},
/*?*/  {0, -5,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, -5,  0,  0, -5},
/*:*/  {0,  9,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, -5,  0,  0,  9},
/*,*/  {0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, -5,  0,  0,  0, -4},
/*id*/ {-3, 2, -3, -3,  2,  2,  2,  2, -3,  2,  2,  2,  2,  2, -3, -3,  2},
/*T/F*/{-3, 2, -3, -3, -6, -6, -6, -6, -3,  2,  2,  2, -6, -6, -3, -3,  2},
/*$*/  {0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0,  0, -7,  0,  0,  1}};
	double result;
	String input;
	ArrayList<Token> stack;
	Scanner scanner;
        int index;
        /**
         * 構(gòu)造函數(shù)
         * @param temp 初始化對象的輸入流
         */
	public Parser(String temp)
	{
		input = temp;
		result = 0;
                index = 0;
		scanner = new Scanner(input);
		stack = new ArrayList<Token>();
                stack.add(new DollarToken());
	}
        /**
         * 查表函數(shù),其中會根據(jù)opp表中的空白項(xiàng)拋出異常
         * @param l 用于查表的左token
         * @param r 用于查表的右token
         * @return 返回查表結(jié)果用于判斷是shift還是reduce
         * @throws exceptions.MissingOperandException 缺少運(yùn)算量異常
         * @throws exceptions.MissingRightParenthesisException 缺少右括號異常
         * @throws exceptions.MissingOperatorException 缺少運(yùn)算符異常
         * @throws exceptions.FunctionCallException 函數(shù)調(diào)用異常
         * @throws exceptions.TrinaryOperationException 三元函數(shù)調(diào)用異常
         * @throws exceptions.TypeMismatchedException 類型不匹配異常
         * @throws exceptions.SyntacticException 語法異常(通常不拋出)
         */
        String search(Token l,Token r) throws 
                MissingOperandException,
                MissingRightParenthesisException,
                MissingOperatorException,
                FunctionCallException,
                TrinaryOperationException,
                TypeMismatchedException,
                SyntacticException
	{
		int indexl = 0,indexr = 0;
                if(l.getType().equals("Decimal")||l.getType().equals("Boolean")||l.getType().equals("$"))
                {for(indexl = 0;indexl < 17;indexl++)if(l.getType().equals(opPos[indexl]))break;}
                else if(l.getType().equals("Operator")||l.getType().equals("Function"))
                {for(indexl = 0;indexl < 17;indexl++)if(l.getToken().equals(opPos[indexl]))break;}
                
                if(r.getType().equals("Decimal")||r.getType().equals("Boolean")||r.getType().equals("$"))
                {for(indexr = 0;indexr < 17;indexr++)if(r.getType().equals(opPos[indexr]))break;}
                else if(r.getType().equals("Operator")||r.getType().equals("Function"))
                {for(indexr = 0;indexr < 17;indexr++) if(r.getToken().equals(opPos[indexr]))break;}
                int address = table[indexl][indexr];
                if(address == 0){return "shift";}
                else if(address == 1){return "accept";}
                else if(address == 2){return "bool";}
                else if(address == 3){return "2y";}
                else if(address == 4){return "()";}
                else if(address == 5){return "-";}
                else if(address == 6){return "2b";}
                else if(address == 7){return "2g";}
                else if(address == 8){return "!";}
                else if(address == 9){return "3y";}
                else if(address == -1){throw new MissingOperandException();}
                else if(address == -2){throw new MissingRightParenthesisException();}
                else if(address == -3){throw new MissingOperatorException();}
                else if(address == -4){throw new FunctionCallException();}
                else if(address == -5){throw new TrinaryOperationException();}
                else if(address == -6){throw new TypeMismatchedException();}
                else if(address == -7){throw new SyntacticException();}
                return "";
	}
        /**
         * shift操作的方法
         * @param temp 用shift的token
         */
        public void shift(Token temp)
        {
            if(!temp.getType().equals("$"))
            {
                stack.add(temp);
            }
        }
        /**
         * reduce方法
         * @param type 指示reduce的操作
         * @throws exceptions.MissingOperandException 缺少運(yùn)算量異常
         * @throws exceptions.MissingOperatorException 缺少運(yùn)算符異常
         * @throws exceptions.MissingRightParenthesisException 缺少右括號異常
         * @throws exceptions.FunctionCallException 函數(shù)調(diào)用異常
         * @throws exceptions.TrinaryOperationException 三元函數(shù)調(diào)用異常
         * @throws exceptions.TypeMismatchedException 類型不匹配異常
         * @throws exceptions.SyntacticException 語法異常(通常不拋出)
         * @throws exceptions.SemanticException 語義異常(通常不拋出)
         */
	public void reduce(String type) throws 
                MissingOperandException,
                MissingOperatorException,
                MissingRightParenthesisException,
                FunctionCallException,
                TrinaryOperationException,
                TypeMismatchedException,
                SyntacticException,
                SemanticException
	{
		if(type.equals("2y"))
		{
			double r = psmd();
			stack.add(new DecimalToken(r));
		}
                if(type.equals("()"))
                {
                    double r = parent();
                    if(r != 2)
                        stack.add(new DecimalToken(r));
                }
                if(type.equals("-"))
                {
                    double r = neg();
                    stack.add(new DecimalToken(r));
                }
                if(type.equals("!"))
                {
                    String r = not();
                    stack.add(new BooleanToken(r));
                }
                if(type.equals("2b"))
                {
                    String r = cmp();
                    stack.add(new BooleanToken(r));
                }
                if(type.equals("2g"))
                {
                    String r = realation();
                    stack.add(new BooleanToken(r));
                }
                if(type.equals("3y"))
                {
                    double r = trinary();
                    stack.add(new DecimalToken(r));
                }
                index = stack.size()-1;
                scanner.forward();
	}
        /**
         * 運(yùn)作整個(gè)paser的方法,控制查表和shift,reduce操作
         * @throws exceptions.IllegalIdentifierException 未定義字符異常
         * @throws exceptions.IllegalDecimalException 數(shù)值格式異常
         * @throws exceptions.IllegalSymbolException 非法字符異常
         * @throws exceptions.MissingOperandException 缺少運(yùn)算量異常
         * @throws exceptions.MissingOperatorException 缺少運(yùn)算符異常
         * @throws exceptions.MissingRightParenthesisException 缺少右括號異常
         * @throws exceptions.FunctionCallException 函數(shù)調(diào)用異常
         * @throws exceptions.TrinaryOperationException 三元函數(shù)調(diào)用異常
         * @throws exceptions.TypeMismatchedException 類型不匹配異常
         * @throws exceptions.SyntacticException 語法異常(通常不拋出)
         * @throws exceptions.SemanticException 語義異常(通常不拋出)
         */
	public void parsing() throws 
                IllegalIdentifierException,
                MissingOperandException,
                MissingOperatorException,
                MissingRightParenthesisException,
                FunctionCallException,
                TrinaryOperationException,
                TypeMismatchedException,
                SyntacticException,
                SemanticException,
                IllegalDecimalException,
                IllegalSymbolException
	{
            Token temp = new DecimalToken(0);
                do
                {
                    index = stack.size()-1;
                    if(stack.get(index).getType().equals("Decimal"))index--;
                    else if(stack.get(index).getType().equals("Boolean"))index--;
                    if(!temp.getType().equals("$"))
                        temp = scanner.getNextToken();
                    String seaR = search(stack.get(index),temp);
                    if(seaR.equals("accept"))continue;
                    if(seaR.equals("shift"))shift(temp);
                    else if(seaR.equals("2y"))reduce("2y");
                    else if(seaR.equals("()"))reduce("()");
                    else if(seaR.equals("-"))reduce("-");
                    else if(seaR.equals("!"))reduce("!");
                    else if(seaR.equals("3y"))reduce("3y");
                    else if(seaR.equals("2b"))reduce("2b");
                    else if(seaR.equals("2g"))reduce("2g");
                    if(stack.get(index).getType().equals("Decimal"))index--;
                    else if(stack.get(index).getType().equals("Boolean"))index--;
                }while(!(stack.get(index).getType().equals("$") && temp.getType().equals("$")));
                if(search(stack.get(index),temp).equals("accept"))
                {
                    if(stack.get(stack.size()-1).getType().equals("Decimal"))
                        result = ((DecimalToken)stack.get(stack.size()-1)).getResult();
                    else throw new TypeMismatchedException();
                }
	}
        /**
         * 獲取parsing結(jié)果的方法
         * @return 返回結(jié)果
         */
	public double getresult()
	{   
		return result;
	}
        /**
         * 規(guī)約二元運(yùn)算的方法
         * @return 運(yùn)算結(jié)果
         * @throws exceptions.MissingOperandException 缺少操作量異常
         * @throws exceptions.DividedByZeroException 除數(shù)為0異常
         * @throws exceptions.MissingOperatorException 缺少操作符異常
         * @throws exceptions.TypeMismatchedException 類型不匹配異常
         */
	double psmd() throws
                MissingOperandException,
                DividedByZeroException,
                MissingOperatorException,
                TypeMismatchedException
	{
		double r = 0,l = 0;
		Token test = stack.remove(stack.size()-1);
		if(test.type.equals("Decimal"))
		{	
			DecimalToken right = (DecimalToken)test;	
			r = right.getResult();
		}else if(test.getType().equals("Operator"))throw new MissingOperandException();
                else throw new TypeMismatchedException();
		Token temp = stack.remove(stack.size()-1);
		test = stack.remove(stack.size()-1);
		if(test.type.equals("Decimal"))
		{
			DecimalToken left = (DecimalToken)test;
			l = left.getResult();
		}else if(test.getType().equals("Operator"))throw new MissingOperandException();
                else throw new TypeMismatchedException();
                if(!temp.getType().equals("Operator"))throw new MissingOperatorException();
                if(temp.toString().equals("+"))return r+l;
                else if(temp.toString().equals("-"))return l-r;
                else if(temp.toString().equals("*"))return r*l;
                else if(temp.toString().equals("/"))
                {
                    if(r == 0)throw new DividedByZeroException();
                    return l/r;
                }
                else if(temp.toString().equals("^"))
                {
                    return Math.pow(l, r);
                }
                return 0;
	}
        /**
         * 規(guī)約括號操作,這里包括函數(shù)的規(guī)約
         * @return 運(yùn)算結(jié)果
         * @throws exceptions.MissingLeftParenthesisException 缺少左括號異常
         * @throws exceptions.MissingRightParenthesisException 缺少右括號異常
         * @throws exceptions.FunctionCallException 函數(shù)調(diào)用異常
         * @throws exceptions.MissingOperandException 缺少操作量異常
         * @throws exceptions.TypeMismatchedException 類型不匹配異常
         */
	double parent() throws
                MissingLeftParenthesisException,
                MissingRightParenthesisException,
                FunctionCallException,
                MissingOperandException,

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜乳av一区二区三区| 亚洲精品成人a在线观看| 国产精品美女久久久久aⅴ| 国产在线精品一区在线观看麻豆| 精品一区在线看| 日韩精品一区二区三区视频| 亚洲成av人片在线观看无码| 成人自拍视频在线| 日韩精品一区二区三区视频| 亚洲曰韩产成在线| 国产精品一区二区在线观看不卡| 欧美日韩一本到| 国产色一区二区| 视频一区欧美日韩| 日本高清不卡aⅴ免费网站| 欧美电视剧在线观看完整版| 有码一区二区三区| aaa亚洲精品| 久久久久久免费网| 香蕉乱码成人久久天堂爱免费| 欧美日精品一区视频| 韩国av一区二区三区在线观看| 久久一区二区三区国产精品| 久久国产精品一区二区| 26uuu国产日韩综合| 亚洲一区二区成人在线观看| 一本色道亚洲精品aⅴ| 日韩高清一级片| 日韩欧美123| 91精品国产一区二区三区香蕉 | 国产精品亚洲人在线观看| www日韩大片| 91精品国产乱| 538prom精品视频线放| 欧美蜜桃一区二区三区| 欧美吞精做爰啪啪高潮| 欧美中文字幕一区二区三区亚洲| 99精品一区二区| 日本韩国一区二区三区| 一本久久精品一区二区| 在线看国产一区二区| 99久久国产综合精品女不卡| 91蜜桃婷婷狠狠久久综合9色| 成人免费毛片app| 成人激情校园春色| jiyouzz国产精品久久| 91影院在线观看| 欧洲一区在线观看| 欧美日韩亚洲丝袜制服| 欧美一区二区观看视频| 精品国产123| 久久色中文字幕| 欧美国产欧美综合| 亚洲欧美日韩国产一区二区三区| 亚洲六月丁香色婷婷综合久久| 一区二区三区日韩精品| 图片区小说区国产精品视频| 蜜臀av性久久久久蜜臀av麻豆| 久久精品国产在热久久| 国产91丝袜在线播放| 91视频你懂的| 极品少妇xxxx偷拍精品少妇| 国产主播一区二区| 91亚洲精品久久久蜜桃网站| 欧美日韩国产成人在线91| 日韩一区二区精品| 国产日韩欧美制服另类| 亚洲精品免费在线观看| 五月激情综合网| 国产成人aaa| 一本大道久久a久久综合| 337p亚洲精品色噜噜狠狠| 26uuu精品一区二区三区四区在线| 中文字幕二三区不卡| 亚洲国产精品久久久久秋霞影院 | 国产精品久久久一区麻豆最新章节| 国产精品久久久久久久久免费丝袜 | 日本不卡一区二区三区高清视频| 久88久久88久久久| 成人黄色大片在线观看| 欧美日韩在线播放三区| 久久亚洲一区二区三区明星换脸 | 韩国在线一区二区| 97se亚洲国产综合自在线观| 欧美一区午夜视频在线观看| 日本一区二区成人| 五月婷婷久久综合| 99在线精品视频| 日韩一区二区三区电影| 亚洲欧洲日韩综合一区二区| 美女一区二区久久| 91久久精品午夜一区二区| www成人在线观看| 亚洲一区二区三区四区五区黄| 国产一区在线看| 欧美乱妇20p| 亚洲日本va午夜在线电影| 精品在线播放免费| 欧美中文一区二区三区| 国产精品素人视频| 久久国产欧美日韩精品| 欧美在线999| 国产精品女主播av| 国产揄拍国内精品对白| 欧美日韩久久久一区| 国产精品久久久久国产精品日日| 美女视频免费一区| 欧美午夜一区二区| 亚洲精品老司机| av成人老司机| 国产午夜精品福利| 免费在线观看一区| 欧美日韩国产另类一区| 亚洲精品免费播放| 97se亚洲国产综合自在线不卡| 国产亚洲女人久久久久毛片| 久久精品国产亚洲a| 日韩一区二区在线看| 五月天中文字幕一区二区| 91精品办公室少妇高潮对白| 最新国产精品久久精品| 成人高清免费在线播放| 久久综合色8888| 久久电影网站中文字幕| 日韩三级视频在线看| 五月天网站亚洲| 欧美另类变人与禽xxxxx| 亚洲一区免费视频| 欧美性猛片xxxx免费看久爱| 一区二区三区四区高清精品免费观看 | 综合分类小说区另类春色亚洲小说欧美| 国产伦精一区二区三区| 精品入口麻豆88视频| 久久9热精品视频| 精品国产乱码91久久久久久网站| 亚洲高清在线视频| 欧美视频在线观看一区| 亚洲午夜激情网页| 欧美日韩成人综合在线一区二区| 一区二区三区**美女毛片| 91国偷自产一区二区使用方法| 亚洲精品大片www| 色网站国产精品| 亚洲国产另类精品专区| 欧美久久一二区| 蜜臀精品久久久久久蜜臀| 日韩一区二区三区四区五区六区| 一区二区三区高清在线| 奇米影视7777精品一区二区| 一区二区三区在线视频免费| 美女诱惑一区二区| 欧美电视剧在线观看完整版| 国产一区二区三区观看| 欧美激情在线一区二区三区| 国产suv精品一区二区三区| 国产清纯白嫩初高生在线观看91 | 91国产成人在线| 视频一区在线播放| 精品久久久久久久久久久久久久久 | 欧美日韩1234| 久久精品av麻豆的观看方式| 久久久久久久综合日本| 972aa.com艺术欧美| 婷婷久久综合九色综合绿巨人| 欧美美女一区二区在线观看| 蜜桃久久精品一区二区| 国产精品视频观看| 欧美伊人精品成人久久综合97 | 中文字幕一区二区在线观看| 色综合天天综合色综合av | av在线一区二区三区| 亚洲午夜久久久久| 欧美精品一区二区三区四区| 成人美女在线视频| 日本中文字幕一区二区视频| 久久精品人人做人人爽97| 色视频成人在线观看免| 人人超碰91尤物精品国产| 国产亚洲自拍一区| 欧美日韩中文字幕一区二区| 国产精品主播直播| 亚洲综合色视频| 国产欧美久久久精品影院| 欧洲亚洲国产日韩| 国产精品一卡二卡| 亚洲bt欧美bt精品777| 国产三级精品三级| 欧美美女一区二区| 成人免费毛片片v| 麻豆一区二区99久久久久| 中文字幕一区二区三区在线观看| 欧美日韩的一区二区| 成人一二三区视频| 蜜臀av一区二区在线观看| 亚洲九九爱视频| 国产欧美日韩另类一区| 欧美一区二区三区四区视频| 成人黄色小视频在线观看| 日韩电影在线观看电影| 亚洲欧美日韩国产中文在线|