全國最多中醫師線上諮詢網站-台灣中醫網
發文 回覆 瀏覽次數:1770
推到 Plurk!
推到 Facebook!

怎麼寫一個能先成除後加減的程式呢?

尚未結案
gpxhill
一般會員


發表:1
回覆:0
積分:0
註冊:2003-11-19

發送簡訊給我
#1 引用回覆 回覆 發表時間:2003-11-19 20:32:19 IP:220.142.xxx.xxx 未訂閱
請問各位大大,怎麼寫一個能先成除後加減的程式呢?(輸入為文字檔test.txt) ex:2 3*5=17 我只知道要先把,中序->後序,但是我不會做.是否有大大能幫個忙,最好是用C語言 發表人 - gpxhill 於 2003/11/19 20:51:20

中階會員


發表:36
回覆:142
積分:70
註冊:2003-07-24

發送簡訊給我
#2 引用回覆 回覆 發表時間:2003-11-21 13:16:43 IP:163.23.xxx.xxx 未訂閱
gpxhill 您好: 首先先去開啟一個文字檔,讀出裡面要運算的資料 ex: 2 18*21-14 當然你要先懂 C 語言檔案指標運用 知道這部份後,就去參考 字串 章節 裡面會提到許多字串運算、拷貝、刪除等等的方法 當你能把任何題目的中序轉為後序 那你應該就能曉得怎麼對轉為後序的字串運算了 atoi(char *s) 是將字串轉為整數的函式 如果在 C ,也許可以考慮用 operator overloading 的方式做 祝順心 ~
william
版主


發表:66
回覆:2535
積分:3048
註冊:2002-07-11

發送簡訊給我
#3 引用回覆 回覆 發表時間:2003-11-21 13:41:44 IP:147.8.xxx.xxx 未訂閱
引言: 請問各位大大,怎麼寫一個能先成除後加減的程式呢?(輸入為文字檔test.txt) ex:2 3*5=17 我只知道要先把,中序->後序,但是我不會做.是否有大大能幫個忙,最好是用C語言 發表人 - gpxhill 於 2003/11/19 20:51:20
Homework >
ritalin35
一般會員


發表:0
回覆:1
積分:0
註冊:2004-12-24

發送簡訊給我
#4 引用回覆 回覆 發表時間:2004-12-24 20:54:11 IP:59.105.xxx.xxx 未訂閱
#include #include #define N 80 int top=0; int strack[N]; push(char ch); char pop(); char preview(); int empty(); int pri(char op); int in2post (char *in , char *post); main() { char in[N],post[N]; int v; clrscr(); gets(in); in2post(in,post); v=eval(post); printf ("%s\n",post); printf ("%s = %d\n",in,v); getch(); } push(char ch )/*將運算子推入堆疊頂端*/ { strack[top ]=ch; } char pop()/*取出堆疊的第一個運算子*/ { return(strack[--top]); } char preview()/*預視堆疊的頂端運算子*/ { return(strack[top-1]); } int empty()/*判斷堆疊是否為空*/ { return(top==0); } int pri(char ch) { switch(ch) { case'(': return(0); case' ': case'-': return(1); case'*': case'/': return(2); } } int eval(char *post ) { int i,l,v,m,n; char ch; l=strlen(post); for (i=0;ipri(op)) push(ch); else { op=pop(); post[pi ]=op; goto next_op; } } } } while (!empty()) { op=pop(); post[pi ]=op; } post[pi]='\0';/*結束*/ }/*end*/
系統時間:2024-05-02 13:27:17
聯絡我們 | Delphi K.Top討論版
本站聲明
1. 本論壇為無營利行為之開放平台,所有文章都是由網友自行張貼,如牽涉到法律糾紛一切與本站無關。
2. 假如網友發表之內容涉及侵權,而損及您的利益,請立即通知版主刪除。
3. 請勿批評中華民國元首及政府或批評各政黨,是藍是綠本站無權干涉,但這裡不是政治性論壇!