国产一区二区精品-国产一区二区精品久-国产一区二区精品久久-国产一区二区精品久久91-免费毛片播放-免费毛片基地

千鋒教育-做有情懷、有良心、有品質的職業教育機構

手機站
千鋒教育

千鋒學習站 | 隨時隨地免費學

千鋒教育

掃一掃進入千鋒手機站

領取全套視頻
千鋒教育

關注千鋒學習站小程序
隨時隨地免費學習課程

當前位置:首頁  >  應聘面試  >  物聯網面試題  > STL教程(六):C++ STL常用容器之stack

STL教程(六):C++ STL常用容器之stack

來源:千鋒教育
發布人:syq
時間: 2022-07-11 17:26:00 1657531560

  1、stack容器的基本概念

  stack是一種先進后出(First In Last Out,FILO)的數據結構,它只有一個出口,形式如圖所示。stack容器允許新增元素,移除元素,取得棧頂元素,但是除了最頂端外,沒有任何其他方法可以存取stack的其他元素。換言之,stack不允許有遍歷行為。 有元素推入棧的操作稱為:push,將元素推出stack的操作稱為pop。

1

  2、stack容器特點

  Stack所有元素的進出都必須符合”先進后出”的條件,只有stack頂端的元素,才有機會被外界取用。 Stack不提供遍歷功能,也不提供迭代器。

  3、stack常用API

  3.1stack構造函數

stack<T> stkT;//stack采用模板類實現, stack對象的默認構造形式:stack(const stack &stk);//拷貝構造函數

  3.2stack賦值操作

stack& operator=(const stack &stk);//重載等號操作符

  3.3stack數據存取操作

push(elem);//向棧頂添加元素 pop();//從棧頂移除第一個元素 top();//返回棧頂元素

  3.4stack大小操作

empty();//判斷堆棧是否為空 size();//返回堆棧的大小

  案例:

#include <iostream>#include<stack>using namespace std;void test()

 {

     stack<int> s;

     s.push(10);

     s.push(20);

     s.push(30);

     s.push(40);

     s.push(50);

     if(s.empty())

     {

        cout<<"空棧"<<endl;

     }

     else

     {

         cout<<"棧的元素個數:"<<s.size()<<endl;

         while(!s.empty())//棧不為空 我就訪問棧頂元素

         {

             cout<<s.top()<<" ";

             s.pop();//出棧 一個數據

         }

     }

 }int main(int argc, char *argv[]){

   test();

    return 0;}

2

 

  4、其他應用場景

  給定一個句子(只包含字母和空格), 將句子中的單詞位置反轉,單詞用空格分割, 單詞之間只有一個空格,前后沒有空格。

  比如: (1) “good good study day day up”-> “up day day study good good ”

  案例:

#include<iostream>#include<stack>using namespace std;int main(){

    string ss;

    stack<string> sstack;

    while(cin>>ss){

        sstack.push(ss);

    }

    while(sstack.size()>1){

        cout<<sstack.top()<<" ";

        sstack.pop();

    }

    cout<<sstack.top()<<endl;

    return 0;}

  更多關于“物聯網培訓”的問題,歡迎咨詢千鋒教育在線名師。千鋒教育多年辦學,課程大綱緊跟企業需求,更科學更嚴謹,每年培養泛IT人才近2萬人。不論你是零基礎還是想提升,都可以找到適合的班型,千鋒教育隨時歡迎你來試聽。

tags:
聲明:本站稿件版權均屬千鋒教育所有,未經許可不得擅自轉載。
10年以上業內強師集結,手把手帶你蛻變精英
請您保持通訊暢通,專屬學習老師24小時內將與您1V1溝通
免費領取
今日已有369人領取成功
劉同學 138****2860 剛剛成功領取
王同學 131****2015 剛剛成功領取
張同學 133****4652 剛剛成功領取
李同學 135****8607 剛剛成功領取
楊同學 132****5667 剛剛成功領取
岳同學 134****6652 剛剛成功領取
梁同學 157****2950 剛剛成功領取
劉同學 189****1015 剛剛成功領取
張同學 155****4678 剛剛成功領取
鄒同學 139****2907 剛剛成功領取
董同學 138****2867 剛剛成功領取
周同學 136****3602 剛剛成功領取
相關推薦HOT