青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

posts - 21,  comments - 9,  trackbacks - 0
今天刷刷我們學(xué)校的OJ。看到了那道我們大家都熟悉的表達式求值題目。去網(wǎng)上搜了下,發(fā)現(xiàn)沒有現(xiàn)成可用的好的算法。于是自己花了點時間寫了個。沒有做過多優(yōu)化,先發(fā)出來再說。
  1#include<stdio.h>
  2#include<string.h>
  3#include<stack>
  4using namespace std;
  5
  6char exp[1100];
  7char num[100];//此數(shù)組用來把字符數(shù)字轉(zhuǎn)化為整數(shù)
  8
  9stack<char> cstack;
 10stack<double> nstack;
 11
 12int n;
 13
 14int convert(int length)
 15{
 16    int value = 0;
 17    for(int i = 0;i < length;++i)
 18    {
 19        value = value * 10 + num[i]-'0';
 20    }

 21    return value;
 22}

 23
 24//判斷a運算符比b優(yōu)先。如果是的話,那么返回1如果不是的話,返回0
 25int order(char a ,char b)
 26{
 27    if(a == '*' || a == '/')
 28    {
 29        return 1;
 30    }

 31    if(a == '+' || a == '-')
 32    {
 33        if(b == '*' || b== '/')
 34            return 0;
 35        else
 36            return 1;
 37    }

 38    return 0;
 39}

 40
 41//這個函數(shù)用來判斷字符是數(shù)字還是運算符
 42
 43int judge(char c)
 44{
 45    if(c <= '9' && c >= '0')
 46        return 1;
 47    else
 48        return 0;
 49}

 50
 51
 52double go(char c,double n1,double n2)
 53{
 54    if(c == '+')
 55        return n1 + n2;
 56    else
 57        if(c == '-')
 58            return n1 - n2;
 59    else
 60        if(c == '*')
 61            return n1 * n2;
 62    else
 63        if(c == '/')
 64            return n1 / n2;
 65    return 0;
 66}

 67
 68int ignoreKuohao(stack<char> &ccstack,stack<double>& nnstack)
 69{
 70    while(!ccstack.empty() && ccstack.top()!='(')
 71    {
 72        char c1 = ccstack.top(); ccstack.pop();
 73        double n1 = nnstack.top();    nnstack.pop();
 74        double n2 = nnstack.top();    nnstack.pop();
 75        if(ccstack.empty())
 76        {
 77            nnstack.push(go(c1,n1,n2));
 78            break;
 79        }

 80        else
 81        {
 82            char c2 = ccstack.top(); ccstack.pop();
 83            if(order(c1,c2))
 84            {
 85                double k = go(c1,n1,n2);
 86                ccstack.push(c2);
 87                nnstack.push(k);
 88            }

 89            else
 90            {
 91                //nnstack.push(n1);
 92                double n3 = nnstack.top();nnstack.pop();
 93                double k = go(c2,n2,n3);
 94                nnstack.push(k);
 95
 96                k = nnstack.top();
 97                nnstack.push(n1);
 98
 99                k = nnstack.top();
100                ccstack.push(c1);
101            }

102        }

103    }

104    if(!ccstack.empty() && ccstack.top() == '(')
105    {
106        ccstack.pop();
107    }

108
109    return 0;
110}

111
112
113
114//事實證明,在沒有括號的情況下,應(yīng)該從前往后進行計算
115void inKuohao()
116{
117    char c = cstack.top();
118    stack<char> ccstack;
119    stack<double> nnstack;
120    //把括號內(nèi)的表達式逆過來
121    int n = nstack.top();
122    nnstack.push(n);
123    nstack.pop();
124    while(c != '(')
125    {
126        cstack.pop();
127        ccstack.push(c);
128
129        nnstack.push(nstack.top());
130        nstack.pop();
131        if(cstack.empty())
132            break;
133        c = cstack.top();
134    }

135    if(!cstack.empty())
136    {
137        cstack.pop();
138    }

139    ignoreKuohao(ccstack,nnstack);
140    nstack.push(nnstack.top());
141    nnstack.pop();
142}

143
144int calc(int j)
145{
146    int i = 0;
147    int length = 0;
148//    stack<char> cstack;
149//    stack<int> nstack;
150    for(i = 0;i <= j ;++i )
151    {
152        if(judge(exp[i]))
153        {
154            num[length ++ ] = exp[i];
155        }

156        else
157        {
158            if(judge(exp[ i - 1]))//如果上一個是數(shù)字的話,就入棧.這個判斷是為了防止出現(xiàn)(2 + 1 )/2。這種情況
159            {
160                int k = convert(length);
161                nstack.push(k);
162                length = 0;
163            }

164            if(exp[i] == ')')
165                {
166                    inKuohao();
167                }

168            else
169                if(exp[i] == '#')
170                    break;
171            else
172                cstack.push(exp[i]);
173        }

174    }

175    if(!cstack.empty())
176    {
177        inKuohao();
178    }

179    int k =(int) nstack.top();
180    printf("%d\n",k);
181    return k;
182}

183
184int main()
185{
186    scanf("%s",exp);
187    int j = strlen(exp);
188    exp[j] = '#';
189    exp[j + 1= '\0';
190    calc(j);
191    return 0;
192}

193
posted on 2011-04-24 21:00 崔佳星 閱讀(302) 評論(0)  編輯 收藏 引用 所屬分類: 數(shù)據(jù)結(jié)構(gòu)和算法

只有注冊用戶登錄后才能發(fā)表評論。
網(wǎng)站導(dǎo)航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


<2025年12月>
30123456
78910111213
14151617181920
21222324252627
28293031123
45678910

常用鏈接

留言簿(1)

隨筆分類

隨筆檔案

文章分類

文章檔案

搜索

  •  

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            久久aⅴ国产欧美74aaa| 国产一区日韩一区| 老司机一区二区三区| 欧美日韩国产不卡| 欧美α欧美αv大片| 国产精品入口福利| 日韩视频亚洲视频| 最近看过的日韩成人| 午夜精品久久久久99热蜜桃导演| 亚洲另类黄色| 乱中年女人伦av一区二区| 欧美一区二区三区四区夜夜大片| 欧美精品综合| 免费看av成人| 精品51国产黑色丝袜高跟鞋| 亚洲一区尤物| 亚洲影音一区| 国产精品久久91| 在线中文字幕一区| 亚洲尤物影院| 欧美午夜宅男影院在线观看| 亚洲免费精品| 亚洲性色视频| 国产精品久久福利| 亚洲色图自拍| 小辣椒精品导航| 国产精品激情电影| 亚洲一区二区三区在线视频| 午夜伦欧美伦电影理论片| 欧美午夜精品久久久久免费视| 99一区二区| 性欧美xxxx大乳国产app| 国产精品乱看| 午夜免费电影一区在线观看| 久久久久国产精品www | 久久露脸国产精品| 久久三级福利| 在线观看亚洲| 免费av成人在线| 日韩天堂av| 欧美在线电影| 伊人婷婷欧美激情| 可以看av的网站久久看| 欧美激情第六页| 99热精品在线| 国产欧美另类| 久久久99免费视频| 亚洲国产mv| 亚洲午夜精品在线| 国产精品亚洲综合久久| 久久精品国产亚洲5555| 欧美激情视频网站| 在线亚洲欧美| 国产一区二区精品在线观看| 男同欧美伦乱| 亚洲无限av看| 欧美凹凸一区二区三区视频| 一本色道久久加勒比88综合| 国产欧美日韩三级| 蜜臀av国产精品久久久久| 亚洲精品欧美| 亚洲私人影院在线观看| 国产午夜精品视频| 欧美成人蜜桃| 欧美一区成人| 99国产精品久久| 久色成人在线| 亚洲综合色激情五月| 国内在线观看一区二区三区| 欧美日本亚洲视频| 久久国产精品久久国产精品| 亚洲三级网站| 老司机精品视频一区二区三区| 中文欧美字幕免费| 亚洲国产成人精品女人久久久 | 免费黄网站欧美| 亚洲午夜电影网| 亚洲二区在线观看| 欧美在线视频免费| 在线视频精品一| 亚洲国产裸拍裸体视频在线观看乱了中文 | 欧美午夜国产| 免费欧美日韩| 久久精品视频在线看| 亚洲午夜视频在线观看| 亚洲成人在线视频播放 | 久久久水蜜桃| 亚洲专区免费| 日韩午夜高潮| 欧美高清视频一区二区三区在线观看| 午夜精品区一区二区三| 一级日韩一区在线观看| 在线免费观看日韩欧美| 国产午夜精品视频免费不卡69堂| 欧美日本免费一区二区三区| 老巨人导航500精品| 欧美一区不卡| 午夜精品久久久久久久白皮肤| 日韩视频在线观看| 亚洲国产黄色| 欧美激情一区二区三区高清视频| 久久久久久久91| 久久久精品动漫| 久久精品成人| 欧美中文字幕视频在线观看| 亚洲欧美韩国| 亚洲视频在线观看三级| 99视频+国产日韩欧美| 亚洲精品久久久久久久久| 亚洲国产精品一区二区尤物区| 黄色精品一二区| 国产一区二区三区奇米久涩| 国产亚洲一区在线| 国内精品久久久久影院色| 国产人成精品一区二区三| 国产精品h在线观看| 国产精品国产a级| 国产精品久久久久久影视| 国产精品你懂的在线欣赏| 国产精品女主播| 国产日韩欧美不卡| 激情成人综合| 亚洲日本一区二区| 一本一本久久| 性做久久久久久久免费看| 久久国产精品久久国产精品| 久久久91精品国产一区二区精品| 久久久久一区二区| 欧美成人精品一区| 最新亚洲电影| 中文在线一区| 久久精品九九| 欧美激情精品久久久六区热门| 欧美人妖在线观看| 国产精品成人在线观看| 国产精品制服诱惑| 在线观看三级视频欧美| 99re成人精品视频| 午夜精品久久一牛影视| 狂野欧美性猛交xxxx巴西| 亚洲国产三级| 亚洲欧美国产毛片在线| 久久久久久噜噜噜久久久精品| 欧美成人亚洲成人| 国产精品久久久久一区| 狠狠色丁香久久婷婷综合_中| 91久久在线| 欧美一区二区三区免费视| 狂野欧美一区| 亚洲伦理一区| 久久国产精品一区二区三区四区 | 国产精品一国产精品k频道56| 一区二区视频免费完整版观看| 一卡二卡3卡四卡高清精品视频| 欧美专区一区二区三区| 91久久精品日日躁夜夜躁国产| 亚洲免费在线看| 欧美激情一区二区三区在线视频| 国产精品免费在线| 亚洲精品久久久久| 久久久久久久999精品视频| 亚洲人成在线观看一区二区| 欧美影视一区| 国产精品盗摄久久久| 亚洲黄色视屏| 久久看片网站| 午夜激情久久久| 欧美日韩国产成人在线| 在线日本成人| 久久国产精品电影| 亚洲私人影院| 欧美久久电影| 亚洲国产午夜| 久久亚洲午夜电影| 亚洲一区综合| 欧美日韩国产系列| 亚洲精品日韩精品| 蜜臀av性久久久久蜜臀aⅴ| 亚洲伊人一本大道中文字幕| 欧美日韩国产bt| 99在线精品免费视频九九视| 欧美电影打屁股sp| 久久久久国产精品一区二区| 国产亚洲毛片在线| 午夜精品影院| 亚洲一区高清| 国产精品久久久久一区二区三区共 | 亚洲一区在线直播| 欧美性做爰毛片| 亚洲色图在线视频| 亚洲精品资源美女情侣酒店| 欧美成人精品h版在线观看| 亚洲成色777777女色窝| 久久久另类综合| 久久精品国产久精国产思思| 好吊一区二区三区| 久久一区国产| 免费人成网站在线观看欧美高清| 在线观看日韩av电影| 欧美韩日一区二区三区|