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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? ex2.java

?? 該程序可將一個四則混合運算分解成一組四元式指令。
?? JAVA
?? 第 1 頁 / 共 2 頁
字號:
/**
 * 該類的主要任務是生成四元式
 * 設置操作符的優先級
 * 將操作符從表達式中提取出來,將操作符及其相關信息掛到列表中,并進行去括號處理
 * 
 */
package ex2;

import java.util.LinkedList;

/**
 * @author 阿贊
 *
 */
public class EX2 {
	private int length;//表達式的長度
	private int[] suffix;//四元式的結果表示符號的下標數組
	private String expression;//表達式
	Operator operator;//創建Operator類對象
	LinkedList list = new LinkedList();//用來儲存操作符及其相關信息
	LinkedList list1 = new LinkedList();//用來儲存四元式
	public EX2(String expression) {//構造方法
		this.expression = expression;
		length = this.expression.length();
		suffix = new int[length];
		Operator();
		Create();
	}
	public int PRI(char c) {//設置操作符的優先級
		if(c == '=') {// = 的優先級為 1
				return 1;
		}
		else if(c == '+'||c == '-') {// + 和 - 的優先級為 2
			return 2;
		}
		else if(c == '*'||c == '/') {// * 和 / 的優先級為 3
			return 3;
		}
		else if(c == '('||c == ')') {// ( 和 ) 的優先級為 4
			return 4;
		}
		else {
			return 0;
		}
	}
	public int Operator() {//將操作符從表達式中提取出來,將操作符及其相關信息掛到列表中,并進行去括號處理
		for(int i =0;i < length;i++) {
			char op = expression.charAt(i);//獲取表達式的第i個字符
			if(op == '='||op == '+'||op == '-'||op == '*'||op == '/'||op == '('||op == ')') {
				operator = new Operator(""+op,i,PRI(op));//創建Operator類對象,以操作符、操作符在表達式中的下標、操作符的優先級為實參
				list.add(operator);//將Operator類的對象加到列表list尾部
			}
		}
		
		int term = 0;//權值
		for(int i = 0;i < list.size();i++) {//進行去括號處理,將括號操作符及其相關信息從列表中移除,對括號內的非括號操作符進行加權
			Operator op =(Operator)list.get(i);//獲取list中第i個元素
			if(op.Get_op().equals("(")) {//遇到一個"(",權值加4
				term = term + 4;
				list.remove(i);//從列表list中移除第i個元素
				i--;//循環變量減1
			}
			else if(op.Get_op().equals(")")) {//遇到一個")",權值減4
				term = term - 4;
				list.remove(i);
				i--;
			}
			else if(term != 0) {
				int pri = op.Get_pri() + term;
				op.Set_pri(pri);
				list.remove(i);
				list.add(i,op);
			}
		}
		System.out.println(list.size());
		/*for(int i = 0;i < list.size();i++) {
			operator = (Operator)list.get(i);
			System.out.println(operator.Get_op());
			System.out.println(operator.Get_suffix());
			System.out.println(operator.Get_pri());
		}*/
		return list.size();
	}
	public void Create() {//生成四元式
		int size = list.size();//獲取表達式列表的長度
		int i = 0;//控制while循環的循環變量
		int NO = 1;//四元式的結果表示符號的下標
		while(true) {//當i=size時,結束循環
			if(list.size() == 1) {
				Operator operator1 = (Operator)list.get(0);//獲取第1個操作符,也是最后一個需要處理的操作符,即"="
				
				if(expression.charAt(operator1.Get_suffix() + 1) == 'T') {
					//生成四元式
					String string = "("+operator1.Get_op()+","+"T"+(--NO)+","+0+","+expression.charAt(0)+")";
					
					list1.add(string);//將四元式掛到列表list1的尾部
					System.out.println(string);
					list.remove(0);//將操作符從列表list中移除
					//System.out.println(operator1.Get_op());
					//break;
				}
				else {
					String str = expression.substring(operator1.Get_suffix() + 1);
					String string = "("+operator1.Get_op()+","+str+","+0+","+expression.charAt(0)+")";
					list1.add(string);//將四元式掛到列表list1的尾部
					System.out.println(string);
					list.remove(0);//將操作符從列表list中移除
					//System.out.println(operator1.Get_op());
					//break;
				}
				
			}
			else if(list.size() == 2) {
				Operator operator1 = (Operator)list.get(0);//獲取操作符
				Operator operator2 = (Operator)list.get(1);
				int pri1 = operator1.Get_pri();//獲取操作符的優先級
				int pri2 = operator2.Get_pri();
				if(pri1 < pri2) {//處理優先級高的操作符
					
					//將表達式拆分成幾個子串
					String str1 = expression.substring(operator1.Get_suffix()+1,
							operator2.Get_suffix());
					String str2 = expression.substring(operator2.Get_suffix()+1);
					String str3 = expression.substring(0,operator1.Get_suffix()+1);
					
					String str = new String();
					
					for(int k = 0;k < str1.length();k++) {
						if(str1.charAt(k) == '(') {
							str1 = str1.substring(k + 1);//消除括號
							k--;
						}
					}
					for(int k = 0;k < str2.length();k++) {
						if(str2.charAt(k) == ')') {
							str2 = str2.substring(0,k);//消除括號
						}
					}
					
					/*
					System.out.println(expression);
					for(int k = 0;k < suffix.length;k++) {
						System.out.print(suffix[k]);
					}
					System.out.println();
					*/
					
					for(int k = 1;k < str2.length() + operator2.Get_suffix() - operator1.Get_suffix();k++) {
						if(expression.charAt(k + operator1.Get_suffix()) != 'T') {
							suffix[k + operator1.Get_suffix()] = NO;//修改四元式的結果表示符號的下標數組中的相應元素
						}
					}
					
					//當前要處理的操作符左右兩邊的數據都為已經處理過的結果
					if(expression.charAt(operator2.Get_suffix() - 1) == 'T' && expression.charAt(operator2.Get_suffix() + 1) == 'T') {
						String string = "("+operator2.Get_op()+","+"T"+suffix[operator2.Get_suffix() - 1]+","+"T"+suffix[operator2.Get_suffix() + 1]+","+"T"+suffix[operator2.Get_suffix()]+")";
						list1.add(string);
						System.out.println(string);
					}
					
					//當前要處理的操作符左邊的數據都為已經處理過的結果
					else if(expression.charAt(operator2.Get_suffix() - 1) == 'T') {
						String string = "("+operator2.Get_op()+","+"T"+suffix[operator2.Get_suffix() - 1]+","+str2+","+"T"+suffix[operator2.Get_suffix()]+")";
						list1.add(string);
						System.out.println(string);
					}
					
					//當前要處理的操作符右邊的數據都為已經處理過的結果
					else if(expression.charAt(operator2.Get_suffix() + 1) == 'T') {
						String string = "("+operator2.Get_op()+","+str1+","+"T"+suffix[operator2.Get_suffix() + 1]+","+"T"+suffix[operator2.Get_suffix()]+")";
						list1.add(string);
						System.out.println(string);
					}
					
					//當前要處理的操作符左右兩邊的數據都未被處理過
					else {
						String string = "("+operator2.Get_op()+","+str1+","+str2+","+"T"+NO+")";
						list1.add(string);
						System.out.println(string);
					}
					
					for(int k = 1;k < str2.length() + operator2.Get_suffix() - operator1.Get_suffix();k++) {
						str = str.concat("T");//將處理過的數據和操作符置換成字符T
						suffix[k + operator1.Get_suffix()] = NO;
					}
					NO++;//四元式的結果表示符號的下標加1
					expression = str3.concat(str);//合并成新的表達式,未處理部分保持不變
					//System.out.println(expression);
					list.remove(1);//將已處理的操作符移除操作符列表
					//System.out.println(operator2.Get_op());
				}
				else {
					list.remove(0);
					//System.out.println(operator1.Get_op());
				}
			}
			else if(list.size() == 3) {
				Operator operator1 = (Operator)list.get(0);//獲取操作符
				Operator operator2 = (Operator)list.get(1);
				Operator operator3 = (Operator)list.get(2);
				int pri1 = operator1.Get_pri();//獲取操作符的優先級
				int pri2 = operator2.Get_pri();
				int pri3 = operator3.Get_pri();
				if(pri1 < pri2 && pri2 >= pri3) {//處理優先級高的操作符
					
					//將表達式拆分成幾個子串
					String str1 = expression.substring(operator1.Get_suffix()+1,
							operator2.Get_suffix());
					String str2 = expression.substring(operator2.Get_suffix()+1,
							operator3.Get_suffix());
					String str3 = expression.substring(0,operator1.Get_suffix()+1);
					String str4 = expression.substring(operator3.Get_suffix());
					
					String str = new String();
					
					for(int k = 0;k < str1.length();k++) {
						if(str1.charAt(k) == '(') {
							str1 = str1.substring(k + 1);//消除括號
							k--;
						}
					}
					for(int k = 0;k < str2.length();k++) {
						if(str2.charAt(k) == ')') {
							str2 = str2.substring(0,k);//消除括號
						}
					}
					/*
					System.out.println(expression);
					for(int k = 0;k < suffix.length;k++) {
						System.out.print(suffix[k]);
					}
					System.out.println();
					*/
					for(int k = 1;k < operator3.Get_suffix() - operator1.Get_suffix();k++) {
						if(expression.charAt(k + operator1.Get_suffix()) != 'T') {
							suffix[k + operator1.Get_suffix()] = NO;//修改四元式的結果表示符號的下標數組中的相應元素
						}
					}
					
					//當前要處理的操作符左右兩邊的數據都為已經處理過的結果
					if(expression.charAt(operator2.Get_suffix() - 1) == 'T' && expression.charAt(operator2.Get_suffix() + 1) == 'T') {
						String string = "("+operator2.Get_op()+","+"T"+suffix[operator2.Get_suffix() - 1]+","+"T"+suffix[operator2.Get_suffix() + 1]+","+"T"+suffix[operator2.Get_suffix()]+")";
						list1.add(string);
						System.out.println(string);
					}
					
					//當前要處理的操作符左邊的數據都為已經處理過的結果
					else if(expression.charAt(operator2.Get_suffix() - 1) == 'T') {
						String string = "("+operator2.Get_op()+","+"T"+suffix[operator2.Get_suffix() - 1]+","+str2+","+"T"+suffix[operator2.Get_suffix()]+")";
						list1.add(string);
						System.out.println(string);
					}
					
					//當前要處理的操作符右邊的數據都為已經處理過的結果
					else if(expression.charAt(operator2.Get_suffix() + 1) == 'T') {
						String string = "("+operator2.Get_op()+","+str1+","+"T"+suffix[operator2.Get_suffix() + 1]+","+"T"+suffix[operator2.Get_suffix()]+")";
						list1.add(string);
						System.out.println(string);
					}
					
					//當前要處理的操作符左右兩邊的數據都未被處理過
					else {
						String string = "("+operator2.Get_op()+","+str1+","+str2+","+"T"+NO+")";
						list1.add(string);

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
蜜桃视频在线观看一区二区| 精品影院一区二区久久久| 亚洲妇女屁股眼交7| 在线欧美一区二区| 三级久久三级久久| 精品国产三级电影在线观看| 国产美女精品一区二区三区| 中文字幕制服丝袜一区二区三区| 成人av电影在线观看| 亚洲蜜臀av乱码久久精品| 欧洲精品一区二区三区在线观看| 亚洲一级二级在线| 日韩精品中午字幕| www.亚洲国产| 亚洲五码中文字幕| 精品国产一区二区亚洲人成毛片 | 91精品国产一区二区三区蜜臀| 日本亚洲视频在线| 国产午夜精品一区二区三区四区| av男人天堂一区| 日本亚洲三级在线| 亚洲国产成人在线| 4438成人网| www.久久久久久久久| 丝袜诱惑制服诱惑色一区在线观看| 26uuu国产日韩综合| 成人av在线电影| 亚洲成av人**亚洲成av**| www久久久久| 欧美色成人综合| 国产一区二区在线电影| 亚洲免费在线观看视频| 精品欧美黑人一区二区三区| av在线综合网| 久久疯狂做爰流白浆xx| 亚洲精品免费在线| 国产午夜精品一区二区三区四区| 欧美探花视频资源| 成人影视亚洲图片在线| 亚洲18色成人| 中文字幕一区av| 精品久久久久久久一区二区蜜臀| 91国产精品成人| 成人亚洲精品久久久久软件| 免费一级片91| 亚洲综合在线免费观看| 亚洲国产高清在线观看视频| 日韩精品一区二区三区视频播放 | 韩国三级在线一区| 偷拍日韩校园综合在线| 亚洲日本免费电影| 欧美国产丝袜视频| 精品毛片乱码1区2区3区| 欧美老女人第四色| 色菇凉天天综合网| 91免费国产视频网站| 国产精品白丝av| 国模少妇一区二区三区| 三级精品在线观看| 一区二区三区国产| 国产精品系列在线| 国产日韩精品视频一区| 精品日韩在线观看| 日韩免费高清av| 日韩手机在线导航| 日韩一区二区三区在线| 欧美麻豆精品久久久久久| 欧美在线一区二区三区| 色欲综合视频天天天| av综合在线播放| av亚洲产国偷v产偷v自拍| 成人动漫中文字幕| 99精品视频一区| 91亚洲午夜精品久久久久久| 97精品久久久久中文字幕 | av在线不卡网| 91亚洲国产成人精品一区二三| 国产成人精品aa毛片| 国产精品自拍三区| 东方欧美亚洲色图在线| 国产麻豆精品一区二区| 国产精品1区2区| 国产成人av一区| 成人国产视频在线观看 | 色八戒一区二区三区| 欧美在线观看视频一区二区三区| 在线观看国产日韩| 777xxx欧美| 精品日韩在线一区| 欧美激情在线免费观看| 亚洲日本丝袜连裤袜办公室| 亚洲精品国产品国语在线app| 亚洲成人自拍偷拍| 日本不卡一二三| 国产麻豆精品久久一二三| 成人午夜电影久久影院| 99久久99久久免费精品蜜臀| 在线观看亚洲一区| 制服视频三区第一页精品| 欧美不卡视频一区| 日本一区二区免费在线 | 欧美日韩国产综合一区二区| 91麻豆精品国产91久久久久| 精品久久久久久久久久久久久久久| 欧美精品一区二区三| 中文字幕在线不卡视频| 亚洲国产sm捆绑调教视频| 久久99久久精品| av激情综合网| 欧美一级黄色大片| 国产日本欧美一区二区| 亚洲午夜精品一区二区三区他趣| 美女视频一区在线观看| 99久久精品一区二区| 欧美日韩国产电影| 国产视频亚洲色图| 亚洲一级片在线观看| 国产精品亚洲人在线观看| 欧美色图免费看| 国产精品视频一区二区三区不卡| 亚洲一区二区三区在线看| 国产伦理精品不卡| 欧美日韩精品一区二区| 国产欧美va欧美不卡在线| 日韩高清欧美激情| 99r国产精品| 欧美成人在线直播| 一二三四区精品视频| 国产精品小仙女| 欧美一区日韩一区| 亚洲欧美激情视频在线观看一区二区三区| 日韩av一区二区三区四区| 99久久综合精品| 精品国产1区二区| 五月激情综合网| 色8久久人人97超碰香蕉987| 精品电影一区二区| 婷婷六月综合网| 在线观看91视频| 国产精品国产三级国产三级人妇 | 热久久国产精品| 色综合一区二区| 久久久影视传媒| 奇米777欧美一区二区| 色婷婷综合久色| 国产精品久99| 成人av电影在线| 欧美国产日产图区| 国产一区二区三区美女| 日韩免费电影网站| 日韩国产欧美一区二区三区| 欧美三级日本三级少妇99| 亚洲三级在线免费| 成人午夜精品在线| 国产丝袜在线精品| 国产精品123| 国产欧美在线观看一区| 国产一级精品在线| 精品不卡在线视频| 激情亚洲综合在线| 精品久久国产字幕高潮| 久久国产夜色精品鲁鲁99| 91精品国产综合久久蜜臀| 亚洲国产成人高清精品| 欧美色视频在线| 亚洲h精品动漫在线观看| 欧美性生活影院| 亚洲成人激情综合网| 欧美人牲a欧美精品| 日韩综合小视频| 欧美一级精品在线| 久久 天天综合| 国产亚洲一区二区三区四区| 国产一区二区免费看| 欧美激情一区二区三区四区| 成人动漫一区二区| 亚洲人快播电影网| 欧美日韩在线一区二区| 午夜a成v人精品| 日韩一区二区麻豆国产| 精品在线播放免费| 国产欧美综合在线观看第十页| 成人黄色777网| 亚洲影院在线观看| 91精品麻豆日日躁夜夜躁| 国产在线一区二区综合免费视频| 久久久精品日韩欧美| 91亚洲男人天堂| 日韩—二三区免费观看av| 久久综合视频网| 91亚洲精品久久久蜜桃| 性感美女久久精品| 久久久一区二区三区| 一本久道久久综合中文字幕| 婷婷六月综合亚洲| 久久精品亚洲乱码伦伦中文| av一区二区三区| 日本不卡不码高清免费观看| 久久久不卡网国产精品二区| 99re8在线精品视频免费播放|