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

CSU OJ - 1183: 計算表達式的值

   題目意思很簡單就是計算含括號的四則運算表達式的值。這個題目很坑爹,剛做的時候,題目描述里面只說里面會有空格,
后面居然把題目描述改了。所以,這個題無論怎么改,都是不對。因為,不知道是哪個坑爹的出題人,把數據里面加了\t,
難道出題人以為\t也是空格。估計,后面修改題目描述,也是發現這個問題后才改的。這可是還是哥了,改了無數多遍,
不處理非法數據就超時,略過非常數據當然直接WA了。好坑爹。
   計算表達式的值,以前嚴蔚敏書上就說用棧構造出來后綴表達式后再計算值。但是這個方法未免太那個了,首先太麻煩了,
雖然算法思路不麻煩。我的做法是直接遞歸計算即可。碰到左括號遞歸計算新的表達式,右括號作為函數終止條件。否則,按照
四則運算的優先級計算當前的表達式。遞歸算法中需要記錄前一個運算符合的優先級,如果前一個運算符的優先級比現在碰到的
運算符的優先級高,那么就應該直接返回答案了
,當前碰到的運算符的計算交給下一次循環好了。

   代碼如下:

#include <stdio.h>
#define MAX (100 + 10)
char szData[MAX];

void TrimSpace(char* pszData)
{
    char* pszRead = pszData;
    char* pszWrite = pszData;
    while (*pszRead)
    {
        //由于數據中有\t,與先前題目描述不符合,不處理掉就直接超時了
        if (*pszRead != ' ' && *pszRead != '\t')
        {
            *pszWrite++ = *pszRead;
        }
        ++pszRead;
    }
    *pszWrite = '\0';
}

//nKind代表前一個運算符合的優先級,開始時是0,+-是1,*/是2
double Cal(char*& pszData, int nKind)
{
    double fAns = 0.0;
    while (*pszData && *pszData != ')')//表達式終止的條件是到達'\0'或者碰到右括號
    {
        if (*pszData >= '0' && *pszData <= '9')
        {
            fAns = 10 * fAns + *pszData - '0';
            ++pszData;
        }
        else if (*pszData == '+')
        {
            if (nKind >= 1)
            {
                return fAns;
            }
            ++pszData;
            fAns += Cal(pszData, 1);
        }
        else if (*pszData == '-')
        {
            if (nKind >= 1)
            {
                return fAns;
            }
            ++pszData;
            fAns -= Cal(pszData, 1);
        }
        else if (*pszData == '*')
        {
            if (nKind >= 2)
            {
                return fAns;
            }
            ++pszData;
            fAns *= Cal(pszData, 2);
        }
        else if (*pszData == '/')
        {
            if (nKind >= 2)
            {
                return fAns;
            }
            ++pszData;
            fAns /= Cal(pszData, 2);
        }
        else if (*pszData == '(')
        {
            ++pszData;
            fAns = Cal(pszData, 0);
            ++pszData;//移到')'后面
            return fAns;//一個括號內的是一個完整的表達式,因此直接返回
        }
    }
    
    return fAns;
}

int main()
{
    while (gets(szData))
    {
        TrimSpace(szData);
        char* pszData = szData;
        printf("%.4f\n", Cal(pszData, 0));
    }
}
   一個遞歸函數能計算出表達式的值,而且能處理優先級和括號,如果是以前的話,我應該是寫不出來的。再把算法的實現細節改改,
應該也能計算出浮點數的表達式了。
   

posted on 2012-03-19 16:26 yx 閱讀(1532) 評論(1)  編輯 收藏 引用 所屬分類: 模擬

評論

# re: CSU OJ - 1183: 計算表達式的值 2013-02-20 10:35 LimitSY

3+5*9/1+(-5*6+4*2-4*(2/1+5-(2+3+(-5*2)-4)+4)*3)/2  回復  更多評論   

<2025年9月>
31123456
78910111213
14151617181920
21222324252627
2829301234
567891011

導航

統計

公告

常用鏈接

留言簿(3)

隨筆分類

隨筆檔案

me

好友

同學

網友

搜索

最新評論

閱讀排行榜

評論排行榜

青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            久久精品成人| 欧美激情一区二区三区全黄 | 久久亚洲国产精品一区二区| 亚洲免费小视频| 亚洲免费影视| 先锋影院在线亚洲| 久久精品日韩一区二区三区| 久久久国产精品一区| 久久精品国产精品亚洲| 免费成人在线观看视频| 欧美成人午夜激情| 亚洲美女性视频| 亚洲永久免费| 久久九九免费视频| 欧美激情亚洲自拍| 国产精品久久久久久久久久免费| 国产精品视频大全| 最新成人av在线| 亚洲一区二区欧美日韩| 欧美在线啊v一区| 欧美第十八页| 一本色道久久88综合亚洲精品ⅰ| 亚洲视频免费| 欧美fxxxxxx另类| 国产精品久久久久久久久久免费看| 国产在线乱码一区二区三区| 亚洲精品视频啊美女在线直播| 欧美日韩一二三区| 国产午夜久久| 中文网丁香综合网| 欧美伊人久久大香线蕉综合69| 亚洲一区三区视频在线观看| 久久久九九九九| 亚洲一级黄色片| 久久欧美中文字幕| 日韩午夜在线播放| 久久精品二区三区| 亚洲国产一区在线观看| 欧美一区二区在线免费播放| 精品51国产黑色丝袜高跟鞋| 欧美va亚洲va国产综合| 亚洲人成毛片在线播放女女| **网站欧美大片在线观看| 欧美日韩国产999| 亚洲第一在线综合网站| 最新国产成人av网站网址麻豆| 你懂的国产精品| 99综合视频| 亚洲高清在线观看一区| 午夜精品久久久久久久99热浪潮| 欧美日韩精品二区第二页| 亚洲桃色在线一区| 欧美一级久久| 亚洲自拍电影| 亚洲网在线观看| 亚洲乱码日产精品bd| 欧美在线观看视频| 99re8这里有精品热视频免费| 亚洲人成在线免费观看| 一区在线播放视频| 99国产精品99久久久久久| 夜夜夜精品看看| 久久露脸国产精品| 亚洲国产裸拍裸体视频在线观看乱了 | 亚洲午夜久久久| 国产精品一区二区a| 蜜乳av另类精品一区二区| 欧美不卡高清| 国产在线精品自拍| 亚洲国产91精品在线观看| 久久精品视频网| 亚洲手机视频| 国产精品v一区二区三区| 亚洲天堂成人在线观看| 最新中文字幕亚洲| 欧美日韩国产a| 亚洲综合成人婷婷小说| 亚洲午夜久久久| 国产欧美精品久久| 久久成人资源| 欧美一二三区精品| 尤物99国产成人精品视频| 麻豆91精品91久久久的内涵| 久久爱另类一区二区小说| 在线观看欧美亚洲| 亚洲二区视频| 欧美视频在线不卡| 国产精品国产亚洲精品看不卡15 | 亚洲精品在线免费| 午夜精品久久久久久| 免费美女久久99| 国产精品久久久久久久久免费樱桃 | 欧美激情免费观看| 日韩一级精品| 99在线精品免费视频九九视| 国产精品视频999| 久久午夜影视| 欧美久久一级| 久久亚洲国产成人| 亚洲精品老司机| 国产精品一区二区a| 欧美激情视频一区二区三区在线播放| 欧美国产精品久久| 欧美在线播放| 欧美日韩国产综合新一区| 久久精品国产一区二区三区免费看| 久久天天躁夜夜躁狠狠躁2022 | 亚洲免费伊人电影在线观看av| 极品少妇一区二区三区| 亚洲毛片在线观看.| 国产一区二区中文| 日韩一级精品| 最新成人在线| 欧美mv日韩mv国产网站| 亚洲欧洲精品成人久久奇米网| 欧美亚洲网站| 亚洲最快最全在线视频| 亚洲国产精品一区二区www在线 | 久久青青草综合| 欧美极品aⅴ影院| 欧美在线视频一区二区| 欧美精品亚洲精品| 欧美成在线视频| 国产亚洲精品综合一区91| 日韩视频免费| 亚洲精品视频啊美女在线直播| 久久高清一区| 欧美一区91| 国产精品九色蝌蚪自拍| 亚洲三级电影在线观看| 亚洲第一区色| 久久精品在线| 久久蜜臀精品av| 国产午夜精品麻豆| 亚洲欧美日韩精品久久| 亚洲欧美综合一区| 欧美视频观看一区| 99视频有精品| 亚洲精品久久久久| 免费视频亚洲| 亚洲国产va精品久久久不卡综合| 一区二区三区在线免费视频| 久久久久久久激情视频| 欧美sm视频| 99精品国产在热久久下载| 欧美日韩成人综合在线一区二区| 亚洲人成在线免费观看| 亚洲小说欧美另类婷婷| 国产精品视频专区| 欧美在线短视频| 亚洲第一中文字幕在线观看| 一区二区欧美日韩视频| 国产精品免费看片| 欧美影院精品一区| 欧美激情一区二区三区蜜桃视频| 亚洲国产免费看| 国产精品va在线播放| 小黄鸭精品aⅴ导航网站入口| 美乳少妇欧美精品| 日韩视频在线一区二区| 国产精品久久久亚洲一区 | 欧美性生交xxxxx久久久| 在线综合亚洲欧美在线视频| 性欧美8khd高清极品| 影音欧美亚洲| 欧美日韩中文字幕在线| 欧美一区1区三区3区公司| 久久影视精品| 亚洲午夜精品一区二区三区他趣| 欧美日韩午夜视频在线观看| 亚洲网站在线| 免费成人美女女| 日韩午夜视频在线观看| 日韩午夜在线播放| 久久婷婷丁香| 亚洲经典自拍| 欧美精品日韩综合在线| 香蕉久久夜色精品| 亚洲国产导航| 午夜日韩视频| 在线看成人片| 亚洲一区亚洲二区| 亚洲大胆女人| 亚洲男人av电影| 国产一在线精品一区在线观看| 免费永久网站黄欧美| 久久九九免费视频| 一区二区高清视频在线观看| 狠狠色综合色综合网络| 欧美精品一区二区三区蜜桃| 欧美一区二区视频网站| 欧美亚洲一区二区在线观看| 黑人一区二区三区四区五区| 欧美色视频日本高清在线观看| 亚洲自拍偷拍一区| 国产精品萝li| 亚洲国产一区二区三区在线播 | 亚洲免费视频在线观看| 亚洲黑丝在线| 国产精品亚洲网站|