亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

javascript中解析四則運算表達式的算法和示例

2019-11-20 14:17:03
字體:
來源:轉載
供稿:網友

在編寫代碼時我們有時候會碰到需要自己解析四則運算表達式的情況,本文簡單的介紹使用JavaScript實現對簡單四則運算表達式的解析。

一、熟悉概念

中綴表示法(或中綴記法)是一個通用的算術或邏輯公式表示方法, 操作符是以中綴形式處于操作數的中間(例:3 + 4)。也就是我們最常用的算術表達式,中綴表達式對于人類來說比較容易理解,但是不易于計算機解析。

逆波蘭表示法(Reverse Polish notation,RPN,或逆波蘭記法),是一種是由波蘭數學家揚?武卡謝維奇1920年引入的數學表達式方式,在逆波蘭記法中,所有操作符置于操作數的后面,因此也被稱為后綴表示法。逆波蘭記法不需要括號來標識操作符的優先級。逆波蘭表示法容易使用堆棧結構對表達式進行解析并計算,所以,這里我們解析四則元素表達式,是先從中綴表達式,轉換為逆波蘭表達式。然后再計算值。

二、轉換流程

中綴表達式轉換為后綴表達式(調度場算法)

1.輸入隊列彈出一個記號
2.如果記號為數字,添加到輸出隊列中
3.如果是一個操作符(+-*/)則比較它與輸出堆棧中棧頂的操作符,如果優先級小于或等于棧頂的操作符,那么將棧頂的操作符彈出并加入輸出隊列(循環,直到上述條件不滿足),最后將本次的操作符壓入堆棧。
4.如果是一個左括號,壓入堆棧
5.如果是一個右括號,從棧中不斷的彈出操作符,并加入輸出隊列,知道棧頂的元素為左括號。彈出左括號,不加入輸出隊列。如果沒有發現左括號,說明原來的表達式中括號不對稱,有錯誤。
6.如果輸入隊列為空,而棧中尚有操作符時,如果棧頂的操作符為左括號,則說明原表達式有不匹配的括號。將棧中的操作符逐個彈出,加入輸出隊列。
7.完成

三、轉換代碼實現

function isOperator(value){	var operatorString = "+-*/()";	return operatorString.indexOf(value) > -1}function getPrioraty(value){	switch(value){		case '+':		case '-':			return 1;		case '*':		case '/':			return 2;		default:			return 0;	}}function prioraty(o1, o2){	return getPrioraty(o1) <= getPrioraty(o2);}function dal2Rpn(exp){	var inputStack = [];	var outputStack = [];	var outputQueue = [];	for(var i = 0, len = exp.length; i < len; i++){		var cur = exp[i];		if(cur != ' ' ){			inputStack.push(cur);		}	}	console.log('step one');	while(inputStack.length > 0){		var cur = inputStack.shift();		if(isOperator(cur)){			if(cur == '('){				outputStack.push(cur);			}else if(cur == ')'){				var po = outputStack.pop();				while(po != '(' && outputStack.length > 0){					outputQueue.push(po);					po = outputStack.pop();				}				if(po != '('){					throw "error: unmatched ()";				}			}else{				while(prioraty(cur, outputStack[outputStack.length - 1]) && outputStack.length > 0){					outputQueue.push(outputStack.pop());				}				outputStack.push(cur);			}		}else{			outputQueue.push(new Number(cur));		}	}	console.log('step two');	if(outputStack.length > 0){		if(outputStack[outputStack.length - 1] == ')' || outputStack[outputStack.length - 1] == '('){			throw "error: unmatched ()";		}		while(outputStack.length > 0){			outputQueue.push(outputStack.pop());		}	}	console.log('step three');	return outputQueue;}console.log(dal2Rpn('1 + 2'));console.log(dal2Rpn('1 + 2 + 3'));console.log(dal2Rpn('1 + 2 * 3'));console.log(dal2Rpn('1 + 2 * 3 - 4 / 5'));console.log(dal2Rpn('( 1 + 2 )'));console.log(dal2Rpn('( 1 + 2 ) * ( 3 - 4 ) / 5'));console.log(dal2Rpn('( 1 + 2 ) * (( 3 - 4 ) / 5)'));

四、逆波蘭表達式求值

1.從輸入隊列中彈出一個記號
2.如果是操作數,加入輸出堆棧
3.如果是一個操作符,從輸出堆棧中彈出兩個操作數并進行計算,并將計算得到的值壓入輸出堆棧。
4.循環操作,如果輸入隊列為空,且輸出堆棧只有一個數則這個數為結果,否則是出現了多余的操作數。

五、計算代碼

function evalRpn(rpnQueue){	var outputStack = [];	while(rpnQueue.length > 0){		var cur = rpnQueue.shift();		if(!isOperator(cur)){			outputStack.push(cur);		}else{			if(outputStack.length < 2){				throw "unvalid stack length";			}			var sec = outputStack.pop();			var fir = outputStack.pop();			outputStack.push(getResult(fir, sec, cur));		}	}	if(outputStack.length != 1){		throw "unvalid expression";	}else{		return outputStack[0];	}}

六、結語

逆波蘭表示法,在初次接觸的時候感覺不太習慣,但是熟悉之后,會發現,其實思路特別簡單,不像中綴表示法,還有各種優先級啊,還有小括號之類的,邏輯特別麻煩,還是逆波蘭表示法比較簡潔,完全不用考慮優先級,也沒用小括號,中括號還有大括號攪局。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
久久精品视频网站| 97超级碰在线看视频免费在线看| 91免费高清视频| 欧美亚洲一区在线| 青青精品视频播放| 国产精品a久久久久久| 国产一区二区在线免费视频| 欧美一级黑人aaaaaaa做受| 欧美成人高清视频| 国产女精品视频网站免费| 亚洲国产精品悠悠久久琪琪| 日韩欧美在线视频日韩欧美在线视频| 亚洲美女久久久| 亚洲国产精品电影在线观看| 日韩中文在线不卡| www.日韩av.com| 亚洲精品成a人在线观看| 亚洲欧美日韩爽爽影院| 欧美大尺度在线观看| 亚洲美女又黄又爽在线观看| 亚洲精品电影网在线观看| 亚洲日韩中文字幕在线播放| 成人网中文字幕| 欧美精品久久一区二区| 国产91精品不卡视频| 91精品久久久久久| 亚洲人成在线一二| 一区二区成人av| 中文.日本.精品| 性欧美xxxx| 亚洲免费视频一区二区| 97激碰免费视频| 日韩男女性生活视频| 日韩国产精品亚洲а∨天堂免| 欧美日韩在线视频首页| 日韩精品欧美国产精品忘忧草| 国内外成人免费激情在线视频网站| 亚洲美腿欧美激情另类| 欧美性猛交xxxxx免费看| 国产亚洲精品日韩| 欧美成人一二三| 欧美高清视频在线播放| 欧美日韩国产第一页| 91高清视频免费观看| 国产日韩中文字幕在线| 黄色成人在线免费| 精品国产乱码久久久久久天美| 国产精品免费一区豆花| 午夜精品久久久久久久99热| 国产午夜精品视频免费不卡69堂| 国产精品黄页免费高清在线观看| 亚洲综合国产精品| 欧美日韩午夜视频在线观看| 久久夜色精品国产| 亚洲一区第一页| 日韩av电影院| 久久99视频精品| 亚洲欧美一区二区三区在线| 国产日韩综合一区二区性色av| 国产伊人精品在线| 色婷婷亚洲mv天堂mv在影片| 欧美国产在线视频| 亚洲xxxx做受欧美| 97精品国产91久久久久久| 精品国内亚洲在观看18黄| 欧美影院在线播放| 久久久国产91| 欧美日韩福利电影| 91成人在线观看国产| 91久久久久久| 欧美午夜精品久久久久久久| 欧美日韩成人在线视频| 国产日韩欧美在线视频观看| 久久久女女女女999久久| 日韩精品免费在线| 国产精品久久久久91| 久久免费精品视频| 欧美性在线视频| 成人免费黄色网| 国产视频在线观看一区二区| 亚洲精品国产精品乱码不99按摩| 97国产精品视频人人做人人爱| 亚洲高清免费观看高清完整版| 激情av一区二区| 欧美猛交ⅹxxx乱大交视频| 欧美性猛xxx| 国产精品久久久久久久美男| 国产精品成人观看视频国产奇米| 国产精品自拍小视频| 日本不卡视频在线播放| 国产在线视频2019最新视频| 亚洲a中文字幕| 国产噜噜噜噜噜久久久久久久久| 97精品视频在线| 岛国视频午夜一区免费在线观看| 亚洲大胆人体在线| 在线观看欧美日韩国产| 亚洲精品视频免费在线观看| 亚洲色图综合网| 亚洲缚视频在线观看| 日韩在线免费观看视频| 91久久久久久国产精品| 国产噜噜噜噜久久久久久久久| 日韩的一区二区| 91禁国产网站| 91精品国产综合久久男男| 日韩成人久久久| 美日韩丰满少妇在线观看| 欧美一级黑人aaaaaaa做受| 久久精视频免费在线久久完整在线看| 精品国内产的精品视频在线观看| 欧美日本精品在线| 精品久久久久久电影| 亚洲一区国产精品| 国产精品电影久久久久电影网| 欧美一级大胆视频| 欧美中在线观看| 久久久免费电影| 色婷婷成人综合| 久久人人爽人人爽爽久久| 久久99热精品这里久久精品| 日韩美女av在线| 91牛牛免费视频| 少妇久久久久久| 少妇激情综合网| 97精品免费视频| 亚洲久久久久久久久久久| 亚洲偷熟乱区亚洲香蕉av| 久久久亚洲福利精品午夜| 欧美成人激情视频| 精品色蜜蜜精品视频在线观看| 中日韩美女免费视频网站在线观看| 亚洲国产婷婷香蕉久久久久久| 午夜精品一区二区三区av| 日韩成人在线视频| 精品视频在线观看日韩| 亚洲国产欧美一区二区丝袜黑人| 色中色综合影院手机版在线观看| 久久久久久com| 亚洲香蕉成人av网站在线观看| 91社影院在线观看| 国产成人精品视频在线| x99av成人免费| 九九热视频这里只有精品| 国产精品视频白浆免费视频| 日韩成人av一区| 亚洲女人天堂成人av在线| 日韩美女视频免费看| 国产精品永久免费| 高清欧美性猛交| 亚洲国产欧美一区二区丝袜黑人| 精品香蕉一区二区三区| 亚洲自拍偷拍视频| 亚洲精品一区在线观看香蕉| 久久免费精品日本久久中文字幕| 国外成人在线直播| 国产精品黄页免费高清在线观看| 久久中文字幕在线视频| 97在线观看视频国产| 青草青草久热精品视频在线网站| 成人黄色av播放免费| 日韩国产欧美精品在线| 91中文字幕在线| 国产高清在线不卡|