真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

C++如何使用一個(gè)棧實(shí)現(xiàn)另一個(gè)棧的排序算法-創(chuàng)新互聯(lián)

小編給大家分享一下C++如何使用一個(gè)棧實(shí)現(xiàn)另一個(gè)棧的排序算法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

成都創(chuàng)新互聯(lián)網(wǎng)站建設(shè)提供從項(xiàng)目策劃、軟件開發(fā),軟件安全維護(hù)、網(wǎng)站優(yōu)化(SEO)、網(wǎng)站分析、效果評(píng)估等整套的建站服務(wù),主營業(yè)務(wù)為成都網(wǎng)站制作、網(wǎng)站建設(shè),App定制開發(fā)以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。成都創(chuàng)新互聯(lián)深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

題目:

一個(gè)棧中元素類型為整型,現(xiàn)在想將該棧從頂?shù)降装磸男〉酱蟮捻樞蚺判?,只許申請(qǐng)一個(gè)輔助棧。

除此之外,可以申請(qǐng)新的變量,但不能申請(qǐng)額外的數(shù)據(jù)結(jié)構(gòu)。如何完成排序?

算法C++代碼:

class Solution
{
public:
  //借助一個(gè)臨時(shí)棧排序源棧
  static void sortStackByStack(stack& s)
  {
    stack* sTemp = new stack;
    while (!s.empty())
    {
      int cur = s.top();
      s.pop();
      //當(dāng)源棧中棧頂元素大于臨時(shí)棧棧頂元素時(shí),將臨時(shí)棧中棧頂元素放回源棧
      //保證臨時(shí)棧中元素自底向上從大到小
      while (!sTemp->empty() && cur > sTemp->top())
      {
        int temp = sTemp->top();
        sTemp->pop();
        s.push(temp);
      }
      sTemp->push(cur);
    }
    //將臨時(shí)棧中的元素從棧頂依次放入源棧中
    while (!sTemp->empty())
    {
      int x = sTemp->top();
      sTemp->pop();
      s.push(x);
    }
  }
};

測試用例程序:

#include 
#include 
using namespace std;
class Solution
{
public:
  //借助一個(gè)臨時(shí)棧排序源棧
  static void sortStackByStack(stack& s)
  {
    stack* sTemp = new stack;
    while (!s.empty())
    {
      int cur = s.top();
      s.pop();
      //當(dāng)源棧中棧頂元素大于臨時(shí)棧棧頂元素時(shí),將臨時(shí)棧中棧頂元素放回源棧
      //保證臨時(shí)棧中元素自底向上從大到小
      while (!sTemp->empty() && cur > sTemp->top())
      {
        int temp = sTemp->top();
        sTemp->pop();
        s.push(temp);
      }
      sTemp->push(cur);
    }
    //將臨時(shí)棧中的元素從棧頂依次放入源棧中
    while (!sTemp->empty())
    {
      int x = sTemp->top();
      sTemp->pop();
      s.push(x);
    }
  }
};
void printStack(stack s)
{
  while (!s.empty())
  {
    cout << s.top() << " ";
    s.pop();
  }
  cout << endl;
}
int main()
{
  stack* s = new stack;
  s->push(5);
  s->push(7);
  s->push(6);
  s->push(8);
  s->push(4);
  s->push(9);
  s->push(2);
  cout << "排序前的棧:" << endl;
  printStack(*s);
  Solution::sortStackByStack(*s);
  cout << "排序后的棧:" << endl;
  printStack(*s);
  system("pasue");
}

運(yùn)行結(jié)果:

排序前的棧:
2 9 4 8 6 7 5
排序后的棧:
9 8 7 6 5 4 2

以上是“C++如何使用一個(gè)棧實(shí)現(xiàn)另一個(gè)棧的排序算法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)網(wǎng)站建設(shè)公司行業(yè)資訊頻道!

另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)建站www.cdcxhl.com,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時(shí)售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價(jià)比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。


文章題目:C++如何使用一個(gè)棧實(shí)現(xiàn)另一個(gè)棧的排序算法-創(chuàng)新互聯(lián)
網(wǎng)頁鏈接:http://weahome.cn/article/gsgis.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部