![數(shù)據(jù)結(jié)構(gòu) 模擬計(jì)算器課程設(shè)計(jì)_第1頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/7/0529e9c6-a949-417a-84bb-abffb6830d85/0529e9c6-a949-417a-84bb-abffb6830d851.gif)
![數(shù)據(jù)結(jié)構(gòu) 模擬計(jì)算器課程設(shè)計(jì)_第2頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/7/0529e9c6-a949-417a-84bb-abffb6830d85/0529e9c6-a949-417a-84bb-abffb6830d852.gif)
![數(shù)據(jù)結(jié)構(gòu) 模擬計(jì)算器課程設(shè)計(jì)_第3頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/7/0529e9c6-a949-417a-84bb-abffb6830d85/0529e9c6-a949-417a-84bb-abffb6830d853.gif)
![數(shù)據(jù)結(jié)構(gòu) 模擬計(jì)算器課程設(shè)計(jì)_第4頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/7/0529e9c6-a949-417a-84bb-abffb6830d85/0529e9c6-a949-417a-84bb-abffb6830d854.gif)
![數(shù)據(jù)結(jié)構(gòu) 模擬計(jì)算器課程設(shè)計(jì)_第5頁(yè)](http://file3.renrendoc.com/fileroot_temp3/2022-3/7/0529e9c6-a949-417a-84bb-abffb6830d85/0529e9c6-a949-417a-84bb-abffb6830d855.gif)
版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、數(shù)據(jù)結(jié)構(gòu)課程設(shè)計(jì)實(shí)驗(yàn)報(bào)告模擬計(jì)算器班 級(jí):學(xué) 號(hào):姓 名:模擬計(jì)算器1、 問題描述對(duì)于模擬計(jì)算器的設(shè)計(jì),實(shí)際便是利用棧對(duì)一個(gè)表達(dá)式求值的問題。要求:對(duì)包含加,減,乘,除,括號(hào)的任意整型表達(dá)式進(jìn)行求解2、 設(shè)計(jì)思路表達(dá)式:任何表達(dá)式都是由操作數(shù)、運(yùn)算符和界限符組成的有意義的式子。表達(dá)式求值時(shí)一般有后綴表示、中綴表示、前綴表示。操作數(shù):可以是常數(shù)、變量、常量。運(yùn)算符:從運(yùn)算對(duì)象上分有單目運(yùn)算符、雙目運(yùn)算符、三目運(yùn)算符。界限符:左右括號(hào)和表達(dá)式結(jié)束符。思 路:我們平時(shí)用到的表達(dá)式即為我們所輸入的表達(dá)式(以 # 結(jié)束),此表達(dá)式為中綴表達(dá)式,只要將此表達(dá)式利用棧來進(jìn)出運(yùn)算的符號(hào)轉(zhuǎn)換為后綴表達(dá)式,之后利
2、用棧來進(jìn)出運(yùn)算的數(shù)字將后綴表達(dá)式的值求出即可。3、 數(shù)據(jù)結(jié)構(gòu)定義一般表達(dá)式的長(zhǎng)度不會(huì)過長(zhǎng)所以將順序棧的容量設(shè)為100已經(jīng)算是比較大了具體數(shù)據(jù)結(jié)構(gòu)如下:# define maxsize 100typedef double datatype1;typedef char datatype2;typedef struct stack1 datatype1 data1maxsize; int top1;/*棧頂元素*/seqstack1,*pseqstack1; /*順序棧*/typedef struct stack2 datatype2 data2maxsize; int top2;/*棧頂元素*/s
3、eqstack2,*pseqstack2; /*順序棧*/4、 系統(tǒng)功能模塊介紹(1) 判斷字符是否為操作數(shù)函數(shù) int isnum(char)當(dāng)輸入表達(dá)式時(shí)要利用棧對(duì)表達(dá)式中的數(shù)字和符號(hào)進(jìn)行進(jìn)棧出棧,因此要判斷表達(dá)式中的內(nèi)容是操作數(shù)、運(yùn)算符還是界限符,給出相關(guān)信息。(2) 求運(yùn)算符優(yōu)先級(jí)函數(shù) int priority(char ) 對(duì)輸入的表達(dá)式中的內(nèi)容,若為運(yùn)算符和界限符則要判斷其優(yōu)先級(jí)已完成其計(jì)算的先后順序。(3) 中綴表達(dá)式轉(zhuǎn)換為后綴表達(dá)式函數(shù) int infix_exp_value(char *,char *) 我們平時(shí)使用的為中綴表達(dá)式,但若利用棧則利用后綴表達(dá)式比較容易計(jì)算,因此
4、要將中綴表達(dá)式轉(zhuǎn)換為后綴表達(dá)式,具體算法步驟如下:<1>count=0,初始化運(yùn)算符棧s,將結(jié)束符# 加入運(yùn)算符棧s中。<2>讀表達(dá)式字符=>w。<3>當(dāng)棧頂為# 并且w也是# 時(shí)結(jié)束;否則循環(huán)做下列步驟: <3.1>如果w是操作數(shù)判斷若count=0直接輸出,讀下一個(gè)字符=>w;轉(zhuǎn)<3>。若 count!=0 追加字符, 讀下一個(gè)字符=>w, 轉(zhuǎn)<3>。 <3.2>w若是運(yùn)算符,則:count=1; <3.2.1>如果棧頂為(并且w為)則(出棧不輸出,讀下一個(gè)字 符=>w,
5、轉(zhuǎn)<3>。 <3.2.1>如果棧頂為(或者棧頂優(yōu)先級(jí)小于w優(yōu)先級(jí),則w入棧,讀下 一個(gè)字符=>w,轉(zhuǎn)<3>。否則:從運(yùn)算符棧中出棧并輸出,轉(zhuǎn)<3>(4) 后綴表達(dá)式的求值函數(shù) double postfix_exp(char *)使用一個(gè)操作數(shù)棧,當(dāng)從左到右掃描表達(dá)式時(shí),每遇到一個(gè)操作數(shù)就送入棧中保存,如果操作數(shù)不止一位,則保存在operand中,遇到下一個(gè)操作數(shù)時(shí),執(zhí)行operand=operand*10+(ch-'0'),便可將操作數(shù)轉(zhuǎn)化為數(shù)字。每遇到一個(gè)運(yùn)算符就從棧中取出兩個(gè)操作數(shù)進(jìn)行當(dāng)前的計(jì)算,然后把結(jié)果在入棧,直到整
6、個(gè)表達(dá)式結(jié)束,這時(shí)送入棧頂?shù)闹稻褪墙Y(jié)果。5、 程序清單# include <stdio.h># include <malloc.h># include <conio.h># define maxsize 100typedef double datatype1;typedef char datatype2;typedef struct stack1 datatype1 data1maxsize; int top1;/*棧頂元素*/seqstack1,*pseqstack1; /*順序棧*/typedef struct stack2 datatype2 data
7、2maxsize; int top2;/*棧頂元素*/seqstack2,*pseqstack2; /*順序棧*/*棧的初始化*/pseqstack1 init_seqstack1(void) pseqstack1 S; S=(pseqstack1)malloc(sizeof(pseqstack1); if(S) S->top1=-1; return S;pseqstack2 init_seqstack2(void) pseqstack2 S; S=(pseqstack2)malloc(sizeof(pseqstack2); if(S) S->top2=-1; return S;/
8、*判斷???/int empty_seqstack1(pseqstack1 S) if(S->top1=-1) return 1; else return 0;int empty_seqstack2(pseqstack2 S) if(S->top2=-1) return 1; else return 0;/*X入棧*/int push_seqstack1(pseqstack1 S,datatype1 X) if(S->top1=maxsize-1) printf("棧滿,無(wú)法入棧!n"); return 0; else S->top1+; S->
9、;data1S->top1=X; return 1; int push_seqstack2(pseqstack2 S,datatype2 X) if(S->top2=maxsize-1) printf("棧滿,無(wú)法入棧!n"); return 0; else S->top2+; S->data2S->top2=X; return 1; /*X出棧*/int pop_seqstack1(pseqstack1 S,datatype1 *X) if(empty_seqstack1(S) return 0; else *X=S->data1S-&
10、gt;top1; S->top1-; return 1; int pop_seqstack2(pseqstack2 S,datatype2 *X) if(empty_seqstack2(S) return 0; else *X=S->data2S->top2; S->top2-; return 1; /*求棧頂元素*/int gettop_seqstack1(pseqstack1 S,datatype1 *X) if(empty_seqstack1(S) return 0; else *X=S->data1S->top1; return 1;int gett
11、op_seqstack2(pseqstack2 S,datatype2 *X) if(empty_seqstack2(S) return 0; else *X=S->data2S->top2; return 1;/*判斷字符是否為操作數(shù)。若是返回1,否則返回0*/int isnum(char c) if(c>='0' && c<='9') return 1; else return 0;/*求后綴表達(dá)式的值*/double postfix_exp(char *A) pseqstack1 S;/*定義棧S*/double o
12、perand=0; double result;/*存放棧頂元素*/double a;/*運(yùn)算符ch前的操作數(shù)出棧存入a*/double b;/*運(yùn)算符ch后的操作數(shù)出棧存入b*/double c;/*c=a ch b*/ char ch;/*存放讀取到的表達(dá)式(A)的字符*/ ch=*A+;/*讀表達(dá)式字符=>A*/ S=init_seqstack1();/*初始化棧*/ while(ch!='#')/*遇到元素!='#'時(shí)*/ if(isnum(ch)/*判斷ch是否為數(shù)字字符,計(jì)算出操作數(shù)*/ operand=operand*10+(ch-'
13、0'); else/*否則*/ if(operand)push_seqstack1(S,operand);/*當(dāng)前字符不是數(shù)字,操作數(shù)結(jié)束,要入棧*/operand=0;if(ch!='' && ch!=' ')pop_seqstack1(S,&b);/*運(yùn)算符ch后的操作數(shù)出棧存入b*/pop_seqstack1(S,&a);/*運(yùn)算符ch前的操作數(shù)出棧存入a*/switch(ch)/*求 a ch b=? ,將結(jié)果賦給 c */ case '+' : c=a+b;break;case '-
14、9; : c=a-b;break;case '*' : c=a*b;break;case '/' :if(b!=0)c=a/b;elseprintf("分母為零!"); push_seqstack1(S,c);/*將c壓入棧中*/ ch=*A+;/*指針向下移動(dòng)一位*/ /*遇到'#'循環(huán)結(jié)束*/ gettop_seqstack1(S,&result);/*此時(shí)棧頂元素即為計(jì)算結(jié)果result*/ return result;/*優(yōu)先級(jí)判斷函數(shù)*/int priority(char op)switch(op)case
15、'#': return 1;case ')': return 2;case '+': case '-': return 3;case '*': case '/': return 4;case '(': return 5;default : return 0; /*將指針infixexp指向的中綴表達(dá)式轉(zhuǎn)換為指針postfixexp指向的后綴表達(dá)式*/int infix_exp_value(char *infixexp,char *postfixexp)pseqstack2 S;/*定
16、義棧S*/int count=0;char w;/*存放讀取到的表達(dá)式(infixexp)的字符*/char c;/*存放棧頂元素*/char topelement;/*存出棧元素*/S=init_seqstack2();/*初始化棧*/if(!S)/*棧的初始化判斷*/printf("棧初始化失敗!");return 0;push_seqstack2(S,'#');/*將結(jié)束符'# '加入運(yùn)算符棧S中*/w=*infixexp;/*讀表達(dá)式字符=>w*/while(gettop_seqstack2(S,&c),c)!='
17、;#'|w!='#')/*<3>棧頂元素不等于'#'或w不等于'#'時(shí)循環(huán)*/if(isnum(w)/*判斷w是否為操作數(shù),若是直接輸出,讀下一個(gè)字符=>w,轉(zhuǎn)<3>*/if(count)*postfixexp=''postfixexp+;count=0;*postfixexp=w;postfixexp+;w=*(+infixexp);else/*w若是運(yùn)算符分類如下*/count=1;if( (gettop_seqstack2(S,&c),c)='(' &&a
18、mp; w=')' )/*如果棧頂為'('并且w為')'則'('出棧不輸出,讀下一個(gè)字符=>w,轉(zhuǎn)<3>*/pop_seqstack2(S,&topelement); /*將'('出棧存入topelement*/w=*(+infixexp);elseif( (gettop_seqstack2(S,&c),c)='(' | priority( (gettop_seqstack2(S,&c),c) ) < priority(w) )/*如果棧頂為'
19、('或者棧頂優(yōu)先級(jí)小于w優(yōu)先級(jí),則w入棧,讀下一個(gè)字符=>w,轉(zhuǎn)<3>*/push_seqstack2(S,w);w=*(+infixexp);else/*否則*/*從運(yùn)算符棧中出棧并輸出,轉(zhuǎn)<3>*/pop_seqstack2(S,&topelement);*postfixexp=topelement;postfixexp+;*postfixexp='#'/*在指針postfixexp指向的后綴表達(dá)式結(jié)尾追加字符'#'*/*(+postfixexp)='0'/*在指針postfixexp指向的后綴表
20、達(dá)式最后追加結(jié)束符'0'*/return 1;/*主函數(shù)*/int main() int i=0;char Amaxsize;char Bmaxsize;printf("請(qǐng)輸入表達(dá)式,如:11+22#,必須以#號(hào)結(jié)尾!n"); /* 1+2*(9+7)-4/2# 23+(12*3-2)/4+34*5/7)+108/9# */Ai=getchar();while(Ai+!='#')Ai=getchar();Ai='0'infix_exp_value(A,B);printf("A=%sn",A);printf("B=%sn",B);printf("上式的結(jié)果為: ");printf("%gn",postfix_exp(B)
溫馨提示
- 1. 本站所有資源如無(wú)特殊說明,都需要本地電腦安裝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ì)自己和他人造成任何形式的傷害或損失。
最新文檔
- 農(nóng)莊租地或轉(zhuǎn)讓合同范本
- 傳媒工作室合伙合同范本
- 光伏安裝居間合同范例
- 2025-2030年中國(guó)鹽酸卡比佐卡因項(xiàng)目投資可行性研究分析報(bào)告
- 企業(yè)工裝裝修合同范本
- 2025年度建筑水電安裝工程知識(shí)產(chǎn)權(quán)保護(hù)合同范本
- 包運(yùn)租船租賃合同范例
- 2025年度建筑幕墻工程玻璃幕墻玻璃制品采購(gòu)合同范本
- 企業(yè)白領(lǐng)轉(zhuǎn)餐飲合同范例
- 2025年中國(guó)情侶裝市場(chǎng)全景評(píng)估及投資規(guī)劃建議報(bào)告
- 新員工入職通識(shí)考試(中軟國(guó)際)
- 四星級(jí)酒店工程樣板房裝修施工匯報(bào)
- 圓翳內(nèi)障病(老年性白內(nèi)障)中醫(yī)診療方案
- 中考物理復(fù)習(xí)備考策略
- 博士后進(jìn)站申請(qǐng)書博士后進(jìn)站申請(qǐng)書八篇
- 小報(bào):人工智能科技科學(xué)小報(bào)手抄報(bào)電子小報(bào)word小報(bào)
- GB/T 41509-2022綠色制造干式切削工藝性能評(píng)價(jià)規(guī)范
- 公安系防暴安全03安檢
- 孫權(quán)勸學(xué)教案全國(guó)一等獎(jiǎng)教學(xué)設(shè)計(jì)
- 企業(yè)生產(chǎn)現(xiàn)場(chǎng)6S管理知識(shí)培訓(xùn)課件
- 五年級(jí)下冊(cè)數(shù)學(xué)課件 第10課時(shí) 練習(xí)課 蘇教版(共11張PPT)
評(píng)論
0/150
提交評(píng)論