目錄
1.概念
2.演算法流程
首頁 Java java教程 實例解析Java中綴表達式的實現

實例解析Java中綴表達式的實現

Aug 22, 2022 pm 05:59 PM
java

本篇文章為大家帶來了關於java的相關知識,其中主要介紹了關於中綴表達式是一個通用的算術或邏輯公式表示方法。中綴表達式不容易被電腦解析,但仍被許多程式語言使用,因為它符合人們的普遍用法。下面一起來看一下,希望對大家有幫助。

實例解析Java中綴表達式的實現

推薦學習:《java影片教學

1.概念

什麼是中綴表達式,什麼是後綴表達式?

從小學開始學習的四則運算,例如:3 (5*(2 3) 7) 類似這種表達式就是中綴表達式。中綴表達式人腦很容易理解,各個算符的優先級,人腦也很容易判斷,先算括弧裡的,再算*,再算,-

但是這種表達式很不利於計算機計算,透過某種方式把前綴表達式轉換為後綴表達式方便計算機進行計算,如3 (5*(2 3) 7)的後綴表達式就是3,5,2,3, ,*, 7, , 。這個表達式計算機很容易計算,為什麼容易計算,透過演算法流程2,就會一個深入的理解。

2.演算法流程

如何把中綴表達式轉換成後綴表達式?比如說3 (5*(2 3) 7)的轉成後綴表達式的流程如何?

運算子優先權:

  • ,- 小於*,/
  • 等於-
  • * 等於/

左括號和右括號作為特殊運算子特殊處理。 (碰到'('不用判斷優先權直接入運算子棧,碰到')',也不用判斷優先權,直接出運算子棧)

大致演算法掌握以下幾個流程:

準備兩個棧,一個是數字棧A,一個是操作符棧( ,-,*,/(,))B等

1.0 對於數字棧A,遇到數字直接入棧A。

2.0 對於運算子堆疊B,分成幾種情況

2.1 碰到'('運算子直接入堆疊

2.2 碰到')'運算符,不停的把操作符棧B出棧,直到遇到')'。 (把'('到')'之間的彈出的運算子依序入堆疊A)

2.3 碰到' ,-,* /'比較當前元素(假設當前元素current)和B棧棧頂的運算子(假設棧頂元素是top)的優先權.

2.3.1 如果top >= current, B堆疊出棧且循環比較,直到top < current退出循環,並且把current入棧

2.3.2 如果top < current, 直接把current入B棧

3.0 掃描完整個字串,如果B棧中還有操作符,依序出棧入A

依照上述演算法示範3 (5*(2 3) 7)的流程:

1,碰到3,3入A堆疊[3,]
2 ,碰到,入B棧  [ ,]
3,碰到(,入B棧  [ ,(]
4,碰到5,入A棧  [3,5]
5,碰到*,*的優先權大於(,入B棧[ ,(,*]
6,碰到(,入B棧[ ,(,*,(]
7,碰到2,入A棧[3,5,2]
8,碰到​​,入B棧[ ,(,*,(, ]
9,碰到3,入A棧  [3,5,2,3]
10,碰到),彈出B棧,直接到'(',把彈出的操作符入A棧。B:[ ,(,*] A:[3,5,2,3, ]
11 ,碰到, 的優先權小於B的棧頂元素*,所以*從B出棧,入A,並把入B。B:[ ,(, ] A:[3,5,2,3, ,* ]
12,碰到7,入A棧  [3,5,2,3, ,*,7]
13,碰到),彈出B棧,直接到'(',把彈出的操作符入A棧。B:[ ] A:[3,5,2,3, ,*,7, ]
14, 掃描完整個字串,判斷B是否為空,不為空把B棧的元素彈出,入A。目前不為空,所以最終A棧的元素為A:[3,5,2,3, ,*,7, , ]

##所以最終A的後綴表達式是3,5,2,3, ,*,7, ,

計算機拿到這個會怎麼計算呢?流程如下:

    碰到數字直接入棧
  • 碰到操作符,直接彈出兩個棧頂元素,透過運算元計算,把結果壓入堆疊
透過步驟1,2循環計算,最後堆疊裡只會有一個元素,這個就是表達式的結果。

我們來演練一下:

1,碰到數字3,5,2,3直接入棧A[3 ,5,2,3]

2,碰到,彈出堆疊頂部2,3,相加得5 入堆疊A[3,5,5]
3,碰到*,彈出堆疊頂部5, 5,相乘得25 入堆疊A[3,25]
4,碰到7,直接入堆疊A[3,25,7]
5,碰到,彈出堆疊25,7,相加得32 入棧A[3,32]
6,碰到,彈出棧頂3,32,相加得35 入棧A[35]

透過上面可以得知,計算機很容易計算,從左到右就能把結果得出。

3 程式碼實作

mid2post 求後綴表達式

calcPostExp 拿到後綴表達式求值

cmpPriority 優先權比較

//优先级
bool cmpPriority(char top, char cur)//比较当前字符与栈顶字符的优先级,若栈顶高,返回true
{
	if ((top == &#39;+&#39; || top == &#39;-&#39;) && (cur == &#39;+&#39; || cur == &#39;-&#39;))
		return true;
	if ((top == &#39;*&#39; || top == &#39;/&#39;) && (cur == &#39;+&#39; || cur == &#39;-&#39; || top == &#39;*&#39; || top == &#39;/&#39;))
		return true;
	if (cur == &#39;)&#39;)
		return true;
	return false;
}
登入後複製

求後綴表達式求值

vector<string> mid2post(string &str)
{

	vector<string>vstr;
	stack<char>cstack;
	for (int i = 0;i<str.size();++i)//扫描字符串
	{
		string temp = "";
		if (str[i] >= &#39;0&#39; && str[i] <= &#39;9&#39;)//若是数字
		{
			temp += str[i];
			while (i + 1<str.size() && str[i + 1] >= &#39;0&#39; && str[i + 1] <= &#39;9&#39;)
			{
				temp += str[i + 1];//若是连续数字
				++i;
			}
			vstr.push_back(temp);
		}
		else if (cstack.empty() || str[i] == &#39;(&#39;)//若栈空或者字符为&#39;(&#39;
			cstack.push(str[i]);
		else if (cmpPriority(cstack.top(), str[i]))//若栈顶元素优先级较高,栈顶元素出栈
		{
			if (str[i] == &#39;)&#39;)//若当前字符是右括号,栈中元素出栈,入字符串数组中,直到遇到&#39;(&#39;
			{
				while (!cstack.empty() && cstack.top() != &#39;(&#39;)
				{
					temp += cstack.top();
					cstack.pop();
					vstr.push_back(temp);
					temp = "";
				}
				cstack.pop();
			}
			else//栈中优先级高的元素出栈,入字符串数组,直到优先级低于当前字符
			{
				while (!cstack.empty() && cmpPriority(cstack.top(), str[i]))
				{
					temp += cstack.top();
					cstack.pop();
					vstr.push_back(temp);
					temp = "";
				}
				cstack.push(str[i]);
			}
		}
		else//当前字符优先级高于栈顶元素,直接入栈
			cstack.push(str[i]);
	}
	while (!cstack.empty())//栈中还存在运算符时,出栈,存入字符串数组
	{
		string temp = "";
		temp += cstack.top();
		cstack.pop();
		vstr.push_back(temp);
	}
	return vstr;
}
登入後複製

對後綴表達式進行求值,主要是根據運算子取出兩個

int calcPostExp(vector<string> & vstr)//对后缀表达式进行求值,主要是根据运算符取出两个操作数进行运算
{
	int num, op1, op2;
	stack<int>opstack;
	for (int i = 0;i<vstr.size();++i)
	{
		string temp = vstr[i];
		if (temp[0] >= &#39;0&#39; && temp[0] <= &#39;9&#39;)//如果当前字符串是数字,利用字符串流转化为int型
		{
			stringstream ss;
			ss << temp;
			ss >> num;
			opstack.push(num);
		}
		else if (vstr[i] == "+")//若是操作符,取出两个操作数,进行运算,并将结果存入
		{
			op2 = opstack.top();
			opstack.pop();
			op1 = opstack.top();
			opstack.pop();
			opstack.push(op1 + op2);
		}
		else if (vstr[i] == "-")
		{
			op2 = opstack.top();
			opstack.pop();
			op1 = opstack.top();
			opstack.pop();
			opstack.push(op1 - op2);
		}
		else if (vstr[i] == "*")
		{
			op2 = opstack.top();
			opstack.pop();
			op1 = opstack.top();
			opstack.pop();
			opstack.push(op1*op2);
		}
		else if (vstr[i] == "/")
		{
			op2 = opstack.top();
			opstack.pop();
			op1 = opstack.top();
			opstack.pop();
			opstack.push(op1 / op2);
		}
	}
	return opstack.top();//最终的栈顶元素就是求解的结果
}
登入後複製

推薦學習:《

java影片教學

以上是實例解析Java中綴表達式的實現的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌
威爾R.E.P.O.有交叉遊戲嗎?
1 個月前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

Java 中的完美數 Java 中的完美數 Aug 30, 2024 pm 04:28 PM

Java 完美數指南。這裡我們討論定義,如何在 Java 中檢查完美數?

Java中的Weka Java中的Weka Aug 30, 2024 pm 04:28 PM

Java 版 Weka 指南。這裡我們透過範例討論簡介、如何使用 weka java、平台類型和優點。

Java 中的史密斯數 Java 中的史密斯數 Aug 30, 2024 pm 04:28 PM

Java 史密斯數指南。這裡我們討論定義,如何在Java中檢查史密斯號?帶有程式碼實現的範例。

Java Spring 面試題 Java Spring 面試題 Aug 30, 2024 pm 04:29 PM

在本文中,我們保留了最常被問到的 Java Spring 面試問題及其詳細答案。這樣你就可以順利通過面試。

突破或從Java 8流返回? 突破或從Java 8流返回? Feb 07, 2025 pm 12:09 PM

Java 8引入了Stream API,提供了一種強大且表達力豐富的處理數據集合的方式。然而,使用Stream時,一個常見問題是:如何從forEach操作中中斷或返回? 傳統循環允許提前中斷或返回,但Stream的forEach方法並不直接支持這種方式。本文將解釋原因,並探討在Stream處理系統中實現提前終止的替代方法。 延伸閱讀: Java Stream API改進 理解Stream forEach forEach方法是一個終端操作,它對Stream中的每個元素執行一個操作。它的設計意圖是處

Java 中的時間戳至今 Java 中的時間戳至今 Aug 30, 2024 pm 04:28 PM

Java 中的時間戳記到日期指南。這裡我們也結合範例討論了介紹以及如何在java中將時間戳記轉換為日期。

Java程序查找膠囊的體積 Java程序查找膠囊的體積 Feb 07, 2025 am 11:37 AM

膠囊是一種三維幾何圖形,由一個圓柱體和兩端各一個半球體組成。膠囊的體積可以通過將圓柱體的體積和兩端半球體的體積相加來計算。本教程將討論如何使用不同的方法在Java中計算給定膠囊的體積。 膠囊體積公式 膠囊體積的公式如下: 膠囊體積 = 圓柱體體積 兩個半球體體積 其中, r: 半球體的半徑。 h: 圓柱體的高度(不包括半球體)。 例子 1 輸入 半徑 = 5 單位 高度 = 10 單位 輸出 體積 = 1570.8 立方單位 解釋 使用公式計算體積: 體積 = π × r2 × h (4

如何在Spring Tool Suite中運行第一個春季啟動應用程序? 如何在Spring Tool Suite中運行第一個春季啟動應用程序? Feb 07, 2025 pm 12:11 PM

Spring Boot簡化了可靠,可擴展和生產就緒的Java應用的創建,從而徹底改變了Java開發。 它的“慣例慣例”方法(春季生態系統固有的慣例),最小化手動設置

See all articles