亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

C++中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式的方法

 更新時(shí)間:2020年04月26日 16:25:29   作者:WuYaoBing  
這篇文章主要介紹了C++中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式的方法,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

本文實(shí)例為大家分享了C++中綴表達(dá)式轉(zhuǎn)后綴表達(dá)式的具體代碼,供大家參考,具體內(nèi)容如下

1、初始化兩個(gè)棧:運(yùn)算符棧s1和儲(chǔ)存中間結(jié)果的棧s2;

2、從左至右掃描中綴表達(dá)式;

3、遇到操作數(shù)時(shí),將其壓s2;

4、遇到運(yùn)算符時(shí),比較其與s1棧頂運(yùn)算符的優(yōu)先級(jí):

1)、如果s1為空,或棧頂運(yùn)算符為左括號(hào)“(”,則直接將此運(yùn)算符入棧;
2)、否則,若優(yōu)先級(jí)比棧頂運(yùn)算符的高,也將運(yùn)算符壓入s1
3)、否則,將s1棧頂?shù)倪\(yùn)算符彈出并壓入到s2中,再次轉(zhuǎn)到(4-1)與s1中新的棧頂運(yùn)算符相比較;

5、遇到括號(hào)時(shí):

1)、如果是左括號(hào)“(”,則直接壓入s1;
2)、如果是右括號(hào)“)”,則依次彈出s1棧頂?shù)倪\(yùn)算符,并壓入s2,直到遇到左括號(hào)為止,此時(shí)將這一對括號(hào)丟棄;

6、重復(fù)步驟2至5,直到表達(dá)式的最右邊;

7、將s1中剩余的運(yùn)算符依次彈出并壓入s2;

8、依次彈出s2中的元素并輸出,結(jié)果的逆序即為中綴表達(dá)式對應(yīng)的后綴表達(dá)式

代碼:

#include<iostream>
#include<cstring>
#include<algorithm> 
#include<stack>
using namespace std;
 
stack<char> s1; //運(yùn)算符棧 
stack<char> s2; //中間結(jié)果棧 
 
int f(const char str){
 int yxj; //優(yōu)先級(jí) 
 switch(str){
 case '*':yxj=5;break;
 case '/':yxj=5;break;
 case '+':yxj=4;break;
 case '-':yxj=4;break;
 }
 return yxj;
 
}
int main(){
 char c[100]="(12+4-13)+6*2";
 //char c[100]="1+((2+3)*4)-5";
 int lenc=strlen(c);
 //讀取字符串 
 for(int i=0;i<lenc;i++){
 if(c[i]>='0'&&c[i]<='9'){ //如果是數(shù)字,直接壓入s2 
 s2.push(c[i]);
 }else if(c[i]=='+'||c[i]=='-'||c[i]=='*'||c[i]=='/'){ //如果是運(yùn)算符 
 while(true){
 if(s1.empty()||s1.top()=='('){ //s1為空 ,或者棧頂為( 
 s1.push(c[i]);
 break;
 }else if(f(c[i])>f(s1.top())){ //當(dāng)前運(yùn)算符優(yōu)先級(jí)大于s1棧頂運(yùn)算符優(yōu)先級(jí) 
 s1.push(c[i]);
 break;
 }
 else{ //小于等于 
 char cc=s1.top();
 s1.pop();
 s2.push(cc);
 }
 }
 }else{
 if(c[i]=='('){ //直接讀入 
 s1.push(c[i]);
 }else{
 while(s1.top()!='('){
 char ccc=s1.top();
 s1.pop();
 s2.push(ccc);
 }
 s1.pop();
 }
 }
 }
 while(!s1.empty()){
 char cccc=s1.top();
 s2.push(cccc);
 s1.pop();
 }
 
 //while(!s2.empty()){ //結(jié)果是逆序的 
 // cout<<s2.top();
 // s2.pop();
 //}
 while(!s2.empty()){
 char c=s2.top();
 s1.push(c);
 s2.pop();
 }
 while(!s1.empty()){ 
 cout<<s1.top();
 s1.pop();
 }
 
 return 0;
}

以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • C++ 類的賦值運(yùn)算符''''=''''重載的方法實(shí)現(xiàn)

    C++ 類的賦值運(yùn)算符''''=''''重載的方法實(shí)現(xiàn)

    這篇文章主要介紹了C++ 類的賦值運(yùn)算符'='重載的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2020-02-02
  • C語言 詳解字符串基礎(chǔ)

    C語言 詳解字符串基礎(chǔ)

    在 C 語言中,字符串實(shí)際上是使用空字符 \0 結(jié)尾的一維字符數(shù)組。因此,\0 是用于標(biāo)記字符串的結(jié)束。空字符(Null character)又稱結(jié)束符,縮寫 NUL,是一個(gè)數(shù)值為 0 的控制字符,\0 是轉(zhuǎn)義字符,意思是告訴編譯器,這不是字符 0,而是空字符
    2022-04-04
  • C語言實(shí)現(xiàn)貪吃蛇游戲代碼

    C語言實(shí)現(xiàn)貪吃蛇游戲代碼

    大家好,本篇文章主要講的是C語言實(shí)現(xiàn)貪吃蛇游戲代碼,感興趣的同學(xué)趕快來看一看吧,對你有幫助的話記得收藏一下
    2022-02-02
  • C++實(shí)現(xiàn)日期類的方法詳解

    C++實(shí)現(xiàn)日期類的方法詳解

    這篇文章主要給大家介紹了C++實(shí)現(xiàn)日期類的方法,文中通過代碼示例給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下
    2024-01-01
  • C++如何過濾出字符串的中文(GBK、UTF-8)

    C++如何過濾出字符串的中文(GBK、UTF-8)

    這篇文章主要給大家介紹了關(guān)于C++如何過濾出字符串的中文的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用C++具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-07-07
  • 詳解C語言中strpbrk()函數(shù)的用法

    詳解C語言中strpbrk()函數(shù)的用法

    這篇文章主要介紹了詳解C語言中strpbrk()函數(shù)的用法,是C語言入門學(xué)習(xí)中的基礎(chǔ)知識(shí),需要的朋友可以參考下
    2015-08-08
  • C++入門筆記之std::vector容器詳解

    C++入門筆記之std::vector容器詳解

    這篇文章主要給大家介紹了關(guān)于C++之std::vector容器的相關(guān)資料,vector,一種隨機(jī)訪問的數(shù)組類型,它提供了對數(shù)組元素的快速、隨機(jī)訪問,以及在序列尾部快速、隨機(jī)的插入和刪除操作,需要的朋友可以參考下
    2021-07-07
  • C++中常見容器類的使用方法詳解(vector/deque/map/set)

    C++中常見容器類的使用方法詳解(vector/deque/map/set)

    C++中常見的容器類有vector、list、deque、map、set、unordered_map和unordered_set。下面將舉例直接說明各個(gè)容器的使用方法,希望對大家有所幫助
    2023-03-03
  • C 語言指針變量詳細(xì)介紹

    C 語言指針變量詳細(xì)介紹

    本文主要介紹C 語言指針變量,這里詳細(xì)介紹了 C語言中指針變量的用法,并附代碼示例及指針變量指向關(guān)系圖幫助大家理解指針,有學(xué)習(xí)C語言指針的朋友可以參考下
    2016-08-08
  • C++圖解單向鏈表類模板和iterator迭代器類模版詳解

    C++圖解單向鏈表類模板和iterator迭代器類模版詳解

    這篇文章主要為大家詳細(xì)介紹了C++圖解單向鏈表類模板和iterator迭代器類模版,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助
    2022-02-02

最新評論