版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、11、蛤蟆的數(shù)據(jù)結(jié)構(gòu)筆記之一棧的應(yīng)用之表達(dá)式求值實(shí)現(xiàn) 本篇名言: “人生不售來回票,一旦動(dòng)身,絕不能復(fù)返?!?繼續(xù)棧應(yīng)用實(shí)現(xiàn),這次是來看下表達(dá)式求值的棧實(shí)現(xiàn)。1. 表達(dá)式求值表達(dá)式求值是設(shè)計(jì)語言編譯中的一個(gè)基本問題,它的實(shí)現(xiàn)是棧應(yīng)用的又一個(gè)典型例子。任何一個(gè)表達(dá)式都是由操作數(shù)(Operand)、運(yùn)算符(operator)和界限符(delimiter)組成。操作數(shù)可以是常數(shù)也可以是變量或變量的標(biāo)識(shí)符。運(yùn)算符可以分為算術(shù)運(yùn)算符、關(guān)系運(yùn)算符和邏輯運(yùn)算符三類。界限符有左右括號(hào)和表達(dá)式結(jié)束符。幾個(gè)算術(shù)四則運(yùn)算的規(guī)則:先乘除,后加減;從左算到右先括號(hào)內(nèi),后括號(hào)外此處實(shí)現(xiàn),假定不出現(xiàn)語法錯(cuò)誤,否則過于復(fù)雜,
2、蛤蟆也不能理解了。2. 運(yùn)算符優(yōu)先級(jí)對(duì)于連個(gè)相繼出現(xiàn)的操作符0 1和0 2有三種關(guān)系:大于、等于和小于。由此可以列出之間的優(yōu)先級(jí)。如卜表:+ -* / ()#+ > >< < <>>- > >< < <>>* > >> > <>>/ > >> > <>>( < << < <=) > >> >>># < << < <=加減乘除優(yōu)先性都低
3、于 “(”但是高于“”,由運(yùn)算從左到右可知,當(dāng) 0仁蔦 令0 1>02 為了算法簡(jiǎn)潔,在表達(dá)式的左邊和右邊虛設(shè)一個(gè)“ #”這一對(duì)“ #表示一個(gè)表達(dá)式求值完成?!埃ā?)“”當(dāng)一對(duì)括號(hào)相遇時(shí)表示括號(hào)內(nèi)已運(yùn)算完成。)”和“(”、“ #和 “、“和“ #無法相繼出現(xiàn)如果出現(xiàn)則表達(dá)式出現(xiàn)語法錯(cuò)誤。為實(shí)現(xiàn)優(yōu)先算法,可以使用兩個(gè)工作棧,一個(gè)是OPTR用于寄存運(yùn)算符,一個(gè)是OPND,用于寄存運(yùn)算數(shù)和運(yùn)算結(jié)果。3. 算法基本思路首先置操作數(shù)棧為空棧,表達(dá)式起始符為“ #為棧底元素。依次讀入表達(dá)式中的每個(gè)字符,若是操作數(shù)則進(jìn) OPND棧,若是運(yùn)算符則和 OPTR棧的 棧頂運(yùn)算符比較優(yōu)先權(quán)作相應(yīng)操作,直至整
4、個(gè)表達(dá)式求值完畢(OPTR棧頂元素和當(dāng)前讀入的字符均為“#”'。4. 求值函數(shù) EvaluateExpressio實(shí)現(xiàn)根據(jù)算法基本思路,代碼實(shí)現(xiàn)如下:int EvaluateExpressio n()int flag;char c;char x,theta;char a,b);In itStack(&OPTR);Push(&OPTR,'#');In itStack(&OPND);flag=getNext (&c);GetTop(OPTR, &x);while(c匸'#' | x != '#')if(
5、flag = 0)flag = getNext(&c);itch(Precede(x, c)case'v':/棧頂元素優(yōu)先級(jí)低Pop(&OPND,&b);Pop(&OPND,& a);Push(&OPND, Operate®, theta, b)GetTop(OPTR, &x);GetTop(OPND, &c); freestack(&OPTR); freestack(&OPND); return c;5. Main函數(shù)實(shí)現(xiàn)Main函數(shù)實(shí)現(xiàn)void mai n()int c;pr in t
6、f( "Please in put one expressi on:"c=EvaluateExpressi on();printf( "Result=%dn" ,c);結(jié)果如下圖1所示:旳 rWindow5syst-eirn32cnnrd.eKe0=1 &l( SJPlease Inirut ons expression :1 *2*3+4/2#Result =9革按耳意型謖F6.源碼可以直接在VS上進(jìn)行編譯運(yùn)行。#include "stdio.h"#include "stdlib.h"#include &
7、quot;ctype.h"typedef int Status;#define STACK_INIT_SIZE100#define STACKINCREMENT10typedef char SElemType;/*放入堆棧的元素的類型*/ typedef structSElemType *base;SElemType *top;int stacksizeSqStack;判斷是否為空棧StatusStackEmpty(SqStackS)if (S.top = S.base)return 1;elsereturn 0;用e返回S的頂元素StatusGetTop(SqStackS, SEl
8、emType *e)if (S.top = S.base)return -1;*e = *(S.top-1);return 1;插入e為新的頂元素StatusPushSqStack *S, SEIemType e)if (S->top - S->base) >= S>stacksize)S->base =(SElemType*)realloc( S->base (S>stacksize+STACKINCREMENT )* sizeof(SElemType) );if(! S->base)exit(-1);S->top = S->bas
9、e +S->stacksize;S->stacksize += STACKINCREMENT ;return 1;/刪除S的頂元素,并用e返回其值StatusPop(SqStack *S, SEIemType *e)if (S->top = S->base)return -1;S->top-;*e = *( S->top);return 1;從棧底到棧頂依次對(duì)S的每個(gè)元素調(diào)用函數(shù)Visit (), 旦失敗操作無效Status ListTraverse( SqStackS,Status (* visit)(SEIemType)SEIemType *p;p=S.
10、base;for(p=S.base;p<S.top;p+)(*visit)(*p);輸出元素eStatusoutput(SElemType e)printf( "%d " ,e);return 1/*計(jì)算整數(shù)表達(dá)式的值/*判斷輸入的某個(gè)字符是否是運(yùn)算符*c表示輸入的字符Statusi n(char c,char op)char *p;p=op;while (*p != '0')if(c = *p)*op數(shù)組中存放系統(tǒng)能識(shí)別的運(yùn)算符return 1;P+;return 0;/case'#': j=6; break;-/*進(jìn)行實(shí)際的運(yùn)算*a
11、, b中分別以整數(shù)的形式存放兩個(gè)待運(yùn)算的操作數(shù) theta中存放代表操作符的字符比較兩個(gè)運(yùn)算符的優(yōu)先級(jí)*a,b中存放待比較的運(yùn)算符*'>'表示 a>b*'0'表示不可能出現(xiàn)的比較*/char Precedehara, char b)int i,j;char pre7=/*運(yùn)算符之間的優(yōu)先級(jí)制作成一張表格*/'>' '>' '<''<' '<' '>' '>''v','v
12、9;,'v','v','v','=','O','>','>','>','>','0','>','>','v','v','v','v','v','0','=';switch (a)case'+': i=0; break;case'-
13、9;: i=1; break;case'*': i=2; break;case'/': i=3; break case'(': i=4; break;case')': i=5; break;case'#': i=6; break;switch (bcase'+': j=0; break;case'-': j=1; break;case'*': j=2; break;case'/': j=3; break;case'(': j=4; br
14、eak;case')': j=5; break;*結(jié)果以整數(shù)的形式返回*/int Operate (nt a, char theta, int b) int “result;case'*': result = i * j; break; case'/': result = i / j; break;retur n result;/*從輸入緩沖區(qū)中獲得下一個(gè)整數(shù)或運(yùn)算符,并通過n帶回到主調(diào)函數(shù)*返回值為1表示獲得的是運(yùn)算符*返回值為0表示獲得的是整形操作數(shù)*/nt getNext(char *n)char c;*n=0;while (c=getch
15、ar()=' );/*跳過一個(gè)或多個(gè)空格 */if (!isdigit(c)/*通過函數(shù)判斷如果字符不是數(shù)字,那么只能是運(yùn)算符*/n=c;do/*能執(zhí)行到該條語句,說明字符是數(shù)字,此處用循環(huán)獲得連續(xù)的數(shù)字*/* n=* n*10+(c- '0');/*把連續(xù)的數(shù)字字符轉(zhuǎn)換成相對(duì)應(yīng)的整數(shù)*/c=getchar(); while(isdigit(c);/*如果下一個(gè)字符是數(shù)字,進(jìn)入下一輪循環(huán)*/un getc(c,stdi n);/*新讀入的字符不是數(shù)字,可能是運(yùn)算符,為了不影響下次讀入,把該字符放回到輸入緩沖區(qū)*/return 0;intEvaluateExpressi on()char a,bGetTop(OPTR, &x);while(c匸'#' | x != '#')if(flag = 0)Push(&OPND,c); flag = getNext(&c);elseGetTop(OPTR, &x); switch(Precede(x, c)case'v':/棧頂元素優(yōu)先級(jí)低Push(&OPTR,c);flag = getNext(&c);break;case'-':/脫括號(hào)并接受下一字符Pop(&OPT
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁(yè)內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫(kù)網(wǎng)僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 辦公機(jī)器和設(shè)備的安裝保養(yǎng)和修理行業(yè)營(yíng)銷策略方案
- 粉屑清掃器市場(chǎng)發(fā)展前景分析及供需格局研究預(yù)測(cè)報(bào)告
- 減壓玩具產(chǎn)品供應(yīng)鏈分析
- 人工智能醫(yī)療行業(yè)營(yíng)銷策略方案
- 保險(xiǎn)領(lǐng)域的理賠行業(yè)營(yíng)銷策略方案
- 磁帶錄像機(jī)商業(yè)機(jī)會(huì)挖掘與戰(zhàn)略布局策略研究報(bào)告
- 為建筑物涂覆防護(hù)漆行業(yè)相關(guān)項(xiàng)目經(jīng)營(yíng)管理報(bào)告
- 制造罐頭食品行業(yè)營(yíng)銷策略方案
- 旅游業(yè)全域透視-領(lǐng)略市場(chǎng)變化引領(lǐng)未來發(fā)展
- 數(shù)值孔徑計(jì)產(chǎn)品供應(yīng)鏈分析
- GB/T 6974.3-2024起重機(jī)術(shù)語第3部分:塔式起重機(jī)
- 綿陽市高中2022級(jí)(2025屆)高三第一次診斷性考試(一診)數(shù)學(xué)試卷(含答案逐題解析)
- 綿陽市高中2022級(jí)(2025屆)高三第一次診斷性考試(一診)化學(xué)試卷
- 福建省泉州市2023-2024學(xué)年高一上學(xué)期期末考試地理試題(解析版)
- 2024年學(xué)校中層干部考核細(xì)則樣本(六篇)
- 2024年協(xié)商一致解除勞動(dòng)合同范例(四篇)
- 工程項(xiàng)目管理信息化方案
- 2024-2025學(xué)年小學(xué)綜合實(shí)踐活動(dòng)一年級(jí)上冊(cè)滬科黔科版教學(xué)設(shè)計(jì)合集
- 大學(xué)數(shù)學(xué)《概率論與數(shù)理統(tǒng)計(jì)》說課稿
- 商檢、法檢、三檢的區(qū)別
- tsg z6002-2010特種設(shè)備焊接操作人員考核細(xì)則
評(píng)論
0/150
提交評(píng)論