午夜国产狂喷潮在线观看|国产AⅤ精品一区二区久久|中文字幕AV中文字幕|国产看片高清在线

    C++二叉樹計(jì)算表達(dá)式
    來源:易賢網(wǎng) 閱讀:2581 次 日期:2015-04-16 15:47:14
    溫馨提示:易賢網(wǎng)小編為您整理了“C++二叉樹計(jì)算表達(dá)式”,方便廣大網(wǎng)友查閱!

    C++二叉樹計(jì)算表達(dá)式,具體代碼如下:

    #include <iostream>

    using namespace std;

    class calc

    {

    enum Type {DATA, ADD, SUB, MULTI, DIV, OPAREN, CPAREN, EOL};

    struct node

    {

    Type type;

    int data;

    node *lchild, *rchild;

    node(Type t, int d=0, node *lc=NULL, node *rc=NULL)

    {

    type=t; data=d; lchild=lc; rchild=rc;

    }

    };

    node *root;

    node *create(char * &s);

    Type getToken (char * &s, int &value);

    int result (node *t);

    public:

    calc (char *s)

    {

    root=create(s);

    }

    int result()

    {

    if (root==NULL) return 0;

    return result(root);

    }

    };

    calc::node *calc::create(char * &s)

    {

    node *p, *root=NULL;

    Type returnType,flag=DATA;

    int value;

    while (*s)

    {

    flag=returnType;

    returnType=getToken(s,value);

    switch (returnType)

    {

    case DATA:

    case OPAREN:

    if (returnType == DATA) p=new node(DATA,value);

    else p=create(s);

    if (root==NULL) root=p;

    else if (root->rchild==NULL) root->rchild=p;

    else root->rchild->rchild=p;

    break;

    case CPAREN:

    case EOL: return root;

    case ADD:

    case SUB:

    root=new node(returnType,0,root);

    break;

    case MULTI:

    case DIV:

    if (root->type==DATA || root->type==MULTI || root->type==DIV || flag==OPAREN)

    root=new node(returnType,0,root);

    else

    root->rchild=new node(returnType,0,root->rchild);

    }

    }

    return root;

    }

    calc::Type calc::getToken(char *&s, int &data)

    {

    char type;

    while (*s==' ') ++s;

    if (*s>='0' && *s<='9')

    {

    data=0;

    while (*s>='0' && *s<='9') {data=data*10+ *s-'0'; ++s;}

    return DATA;

    }

    if (*s == '\0') return EOL;

    type =*s; ++s;

    switch(type)

    {

    case '+':return ADD;

    case '-':return SUB;

    case '*':return MULTI;

    case '/':return DIV;

    case '(':return OPAREN;

    case ')':return CPAREN;

    default: return EOL;

    }

    }

    int calc::result(node *t)

    {

    int num1,num2;

    if (t->type == DATA) return t->data;

    num1=result(t->lchild);

    num2=result(t->rchild);

    switch(t->type)

    {

    case ADD:t->data=num1+num2;break;

    case SUB:t->data=num1-num2;break;

    case MULTI: t->data=num1*num2;break;

    case DIV:t->data=num1/num2;break;

    }

    return t->data;

    }

    int main()

    {

    char expression[256];

    cin>>expression;

    calc exp(expression);

    cout<<exp.result()<<endl;

    return 0;

    }

    更多信息請查看IT技術(shù)專欄

    更多信息請查看技術(shù)文章
    易賢網(wǎng)手機(jī)網(wǎng)站地址:C++二叉樹計(jì)算表達(dá)式
    由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

    2025國考·省考課程試聽報(bào)名

    • 報(bào)班類型
    • 姓名
    • 手機(jī)號
    • 驗(yàn)證碼
    關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡要咨詢 | 簡要咨詢須知 | 新媒體/短視頻平臺 | 手機(jī)站點(diǎn) | 投訴建議
    工業(yè)和信息化部備案號:滇ICP備2023014141號-1 云南省教育廳備案號:云教ICP備0901021 滇公網(wǎng)安備53010202001879號 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號
    云南網(wǎng)警備案專用圖標(biāo)
    聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號:hfpxwx
    咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
    云南網(wǎng)警報(bào)警專用圖標(biāo)