欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

C語(yǔ)言實(shí)現(xiàn)逆波蘭式實(shí)例

 更新時(shí)間:2013年09月10日 15:11:39   作者:  
這篇文章介紹了C語(yǔ)言實(shí)現(xiàn)逆波蘭式實(shí)例,有需要的朋友可以參考一下

復(fù)制代碼 代碼如下:

#include<stdio.h>
#include<string.h>

typedef struct{char s[20][20];int top;}SQ;

void copystr(char *a,char *b)
{
    int i=0;
    do
    {
        b[i]=a[i];
        i++;
    }
    while(a[i]!='\0');
    b[i]='\0';
}

void voidSQ(SQ *s)
{
    s->top=-1;
}

int ifempty(SQ *s)
{
    return(s->top==-1);
}

void push(SQ *S,char *c)
{
    if(S->top==19)
        printf("over flow\n");
    else
    {

        S->top++;
        copystr(c,S->s[S->top]);
    }
}
char *pop(SQ *S)
{
    if(ifempty(S))
    {
        printf("over flow!\n");
        return(NULL);
    }
    else
        return(S->s[S->top--]);
}

int judge(char *c)
{
    if(c[1]=='\0')
        switch(c[0])
    {
        case '+':return(3);
        case '-':return(3);
        case '*':return(2);
        case '/':return(2);
        default:return(1);
    }
    else
        return(1);
}

void write(char *a,char *b,char *c)
{
    strcat(a,c);
    strcat(a,b);
}

int seek(char *c,int start)
{
    int signal=1;
    for(start=start++;c[start]!='\0'&&signal!=0;start++)
    {
        if(c[start]==')')
            signal--;
        else if(c[start]=='(')
            signal++;
    }
    if(signal==0)
        return(start-1);
    else
    {
        printf("輸入無(wú)效式子\n");
        return(-1);
    }
}
void FB(SQ *A,SQ *B)
{
    for(;!ifempty(A);)
    {
        push(B,A->s[A->top]);
        pop(A);
    }
}

char *rewrite(char *A)
{
    SQ front;
    SQ back;
    int i,j,k,flag=0;
    char *result;
    char mid[20];
    voidSQ(&front);
    voidSQ(&back);
    for(i=0;A[i]!='\0';)
    {
        if(A[i]=='(')
        {
            j=seek(A,i);
            for(k=i+1;k<j;k++)
            {
                mid[k-i-1]=A[k];
            }
            mid[j-i-1]='\0';
            copystr(rewrite(mid),mid);
            push(&back,mid);
            i=j+1;
        }
        else if(A[i]!='(')
        {
            mid[0]=A[i];
            mid[1]='\0';
            push(&back,mid);
            i++;
        }
    }
    FB(&back,&front);
    for(;front.top>=2;)
    {
        flag=0;
        for(i=0;i<=front.top;i++)
        {
            if(judge(front.s[i])==2)
            {
                flag=1;
                break;
            }

        }
        if(flag==1)
        {
            for(;front.top>=2;)
            {
                if(judge(front.s[front.top])==1&&judge(front.s[front.top-1])==2&&judge(front.s[front.top-2])==1)
                {
                    write(front.s[front.top],front.s[front.top-1],front.s[front.top-2]);
                    push(&back,front.s[front.top]);
                     pop(&front);
                    pop(&front);
                     pop(&front);
                }
                else
                {
                    push(&back,front.s[front.top]);
                    pop(&front);
                }
            }
            FB(&front,&back);
            FB(&back,&front);
        }
        else
        {
            for(;front.top>=2;)
            {
                if(judge(front.s[front.top])==1&&judge(front.s[front.top-1])==3&&judge(front.s[front.top-2])==1)
                {
                    write(front.s[front.top],front.s[front.top-1],front.s[front.top-2]);

                    push(&back,front.s[front.top]);
                     pop(&front);
                    pop(&front);
                     pop(&front);
                }
                else
                {
                    push(&back,front.s[front.top]);
                    pop(&front);
                }
            }
            FB(&front,&back);
            FB(&back,&front);
        }
    }
    result=front.s[front.top];
    return(result);
}

typedef struct{char c[20];int top;}sq;
int execute(char a,char b,char c)
{
    switch(a)
    {
    case('+'):return((c-48)+(b-48));
    case('-'):return((c-48)-(b-48));
    case('*'):return((c-48)*(b-48));
    case('/'):return((c-48)/(b-48));
    }
}

void voidsq(sq *s)
{
    s->top=-1;
}

int ifsqempty(sq *s)
{
    return(s->top==-1);
}

void pushsq(sq *s,char x)
{
    if(s->top==19)
        printf("over flow!\n");
    else
    {
        s->top=s->top+1;
        s->c[s->top]=x;
    }
}

void popsq(sq *s)
{
    if(ifsqempty(s))
        printf("over flow!\n");
    else
        s->top--;
}

int just(char c)
{   
    switch(c)
    {
        case ('+'):return(0);
        case ('-'):return(0);
        case ('*'):return(0);
        case ('/'):return(0);
        default:return(1);
    }
}

void restread(sq *a,sq *b)
{
    for(;!ifsqempty(a);)
    {
        pushsq(b,a->c[a->top]);
        popsq(a);
    }
}


int calculate(char *c)
{
    sq rest,read;
    int i,re;
    voidsq(&rest);
    voidsq(&read);
    for(i=0;c[i]!='\0';i++)
        pushsq(&read,c[i]);
    for(;read.top>=2;)
    {
        for(;read.top>=2;)
        {
            if(just(read.c[read.top])==0&&just(read.c[read.top-1])==1&&just(read.c[read.top-2]) ==1)
            {

                re=execute(read.c[read.top],read.c[read.top-1],read.c[read.top-2]);
                pushsq(&rest,re+48);
                popsq(&read);
                popsq(&read);
                 popsq(&read);
            }
            else
            {
                pushsq(&rest,read.c[read.top]);
                popsq(&read);
            }
        }
        restread(&read,&rest);
        restread(&rest,&read);
    }
    return(read.c[0]-48);
}


void main()
{
    char re[20];
    char a[20];
    printf("請(qǐng)輸入算式:\n");
    scanf("%s",a);
    copystr(rewrite(a),re);
    printf("逆波蘭式:\n%s\n",re);
    printf("求值結(jié)果:\n%d\n",calculate(re));

}

您可能感興趣的文章:

相關(guān)文章

  • 如何使用遞歸和非遞歸方式反轉(zhuǎn)單向鏈表

    如何使用遞歸和非遞歸方式反轉(zhuǎn)單向鏈表

    以下是對(duì)使用遞歸和非遞歸方式反轉(zhuǎn)單向鏈表的示例進(jìn)行了詳細(xì)的分析介紹,需要的朋友可以過(guò)來(lái)參考下
    2013-07-07
  • C++友元函數(shù)與拷貝構(gòu)造函數(shù)詳解

    C++友元函數(shù)與拷貝構(gòu)造函數(shù)詳解

    這篇文章主要介紹了C++友元函數(shù)與拷貝構(gòu)造函數(shù),需要的朋友可以參考下
    2014-07-07
  • Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信

    Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信

    這篇文章主要為大家詳細(xì)介紹了Qt網(wǎng)絡(luò)編程實(shí)現(xiàn)TCP通信,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-08-08
  • 對(duì)比C語(yǔ)言中memccpy()函數(shù)和memcpy()函數(shù)的用法

    對(duì)比C語(yǔ)言中memccpy()函數(shù)和memcpy()函數(shù)的用法

    這篇文章主要介紹了對(duì)比C語(yǔ)言中memccpy()函數(shù)和memcpy()函數(shù)的用法,二者都是用于復(fù)制內(nèi)存內(nèi)容,注意區(qū)別,需要的朋友可以參考下
    2015-08-08
  • C++學(xué)習(xí)之Lambda表達(dá)式的用法詳解

    C++學(xué)習(xí)之Lambda表達(dá)式的用法詳解

    Lambda?表達(dá)式(lambda?expression)是一個(gè)匿名函數(shù),Lambda表達(dá)式基于數(shù)學(xué)中的λ演算得名。本文就來(lái)為大家詳細(xì)講講C++中Lambda表達(dá)式的使用,需要的可以參考一下
    2022-07-07
  • C++、C語(yǔ)言和JAVA開發(fā)的區(qū)別

    C++、C語(yǔ)言和JAVA開發(fā)的區(qū)別

    這篇文章主要給大家介紹了C++和C語(yǔ)言和JAVA開發(fā)的區(qū)別介紹,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友參考下吧
    2017-04-04
  • C++ OpenCV實(shí)現(xiàn)圖像修復(fù)功能

    C++ OpenCV實(shí)現(xiàn)圖像修復(fù)功能

    這篇文章主要介紹了通過(guò)C++ OpenCV中提供的inpaint API實(shí)現(xiàn)對(duì)有瑕疵的圖像進(jìn)行修復(fù),文中的方法講解詳細(xì),感興趣的同學(xué)可以跟隨小編一起學(xué)習(xí)一下
    2022-01-01
  • C++ Array容器的顯示和隱式實(shí)例化詳細(xì)介紹

    C++ Array容器的顯示和隱式實(shí)例化詳細(xì)介紹

    這篇文章主要介紹了C++中Array容器的隱式實(shí)例化和顯式實(shí)例化,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧
    2022-10-10
  • C 語(yǔ)言環(huán)境設(shè)置詳細(xì)講解

    C 語(yǔ)言環(huán)境設(shè)置詳細(xì)講解

    本文主要介紹C 語(yǔ)言環(huán)境設(shè)置,在不同的系統(tǒng)平臺(tái)上,C語(yǔ)言的環(huán)境設(shè)置不同,這里幫大家整理了Liunx, UNIX,Windows 上安裝C語(yǔ)言環(huán)境,有開始學(xué)習(xí)C語(yǔ)言的朋友可以參考下
    2016-08-08
  • C語(yǔ)言?模擬實(shí)現(xiàn)strlen函數(shù)詳解

    C語(yǔ)言?模擬實(shí)現(xiàn)strlen函數(shù)詳解

    在 C 語(yǔ)言 中我們要獲取 字符串 的長(zhǎng)度,可以使用strlen 函數(shù),strlen 函數(shù)計(jì)算字符串的長(zhǎng)度時(shí),直到空結(jié)束字符,但不包括空結(jié)束字符,因?yàn)?nbsp;strlen 函數(shù)時(shí)不包含最后的結(jié)束字符的,因此一般使用 strlen函數(shù)計(jì)算的字符串的長(zhǎng)度會(huì)比使用 sizeof 計(jì)算的字符串的字節(jié)數(shù)要小
    2022-04-04

最新評(píng)論