棧的壓入、彈出序列

来源:http://www.cnblogs.com/sankexin/archive/2016/06/27/5619996.html
-Advertisement-
Play Games

題目:判斷一數字序列是否為這些數字入棧的一種出棧方式(前提:棧中的數字不重覆) 思路1:如果下一個彈出的數字剛好是棧頂數字,那麼直接彈出。如果下一個彈出的數字不在棧頂,我們把壓棧序列還沒有入棧的數字壓入輔助棧,知道把下一個要彈出的數字壓入棧頂為止。如果所有的數字都壓入了仍然沒有找到下一個彈出的數字, ...


題目:判斷一數字序列是否為這些數字入棧的一種出棧方式(前提:棧中的數字不重覆)

思路1:如果下一個彈出的數字剛好是棧頂數字,那麼直接彈出。如果下一個彈出的數字不在棧頂,我們把壓棧序列還沒有入棧的數字壓入輔助棧,知道把下一個要彈出的數字壓入棧頂為止。如果所有的數字都壓入了仍然沒有找到下一個彈出的數字,那麼該序列不可能是一個彈出序列。

思路2:開闢一個輔助棧,模擬入棧出戰過程(假設pa為入棧序列,pb為出戰序列),pA中的元素依次壓入輔助棧,新壓入的元素與彈出序列的棧底相同,輔助棧彈出,同時pB向上移動,不相同了pB中的元素繼續入輔助棧。

 1 #include "stdafx.h"
 2 #include <stack>
 3 
 4 //方法1 
 5 bool IsPopOrder(const int* pPush, const int* pPop, int nLength)
 6 {
 7     bool bPossible = false;
 8     
 9     if(pPush != NULL && pPop != NULL && nLength > 0)
10     {
11         const int* pNextPush = pPush;
12         const int* pNextPop = pPop;
13         
14         std::stack<int> stackData;
15         
16         while(pNextPop - pPop < nLength)
17         {
18             // 當輔助棧的棧頂元素不是要彈出的元素
19             // 先壓入一些數字入棧
20             while(stackData.empty() || stackData.top() != *pNextPop)
21             {
22                 // 如果所有數字都壓入輔助棧了,退出迴圈
23                 if(pNextPush - pPush == nLength)
24                     break;
25                 
26                 stackData.push(*pNextPush);
27                 
28                 pNextPush ++;
29             }
30             
31             if(stackData.top() != *pNextPop)
32                 break;
33         
34             stackData.pop();
35             pNextPop ++;
36         }
37         
38         if(stackData.empty() && pNextPop - pPop == nLength)
39             bPossible = true;
40     }
41     
42     return bPossible;
43     
44 }
45 
46 //方法2 
47 bool IsPopOrder1(const int* pPush, const int* pPop, int lengthA, int lengthB)
48 {
49     if( lengthA != lengthB || lengthA == 0)
50         return false;
51     bool flag = false;
52 
53     int pA =0;
54     int pB =0;
55     int *newpPush = new int[lengthA];
56     int top = -1;
57     for(pA = 0 ; pA < lengthA; ++pA)
58     {
59         ++top;
60         newpPush[top] = pPush[pA];
61         while(newpPush[top] == pPop[pB])
62         {
63             --top;
64             ++pB;
65         }
66     }
67     if(top == -1)
68         flag = true;
69     delete []newpPush;
70     return flag;
71 }
72 
73 int main()
74 {
75     const int nLength = 5 ;
76     int push[nLength] = {1,2,3,4,5};
77     int pop[nLength] = {4, 5, 3, 2, 1};
78     
79     bool  flag1 = IsPopOrder(push, pop, nLength);
80     printf("Solution 1 is %d\n", flag1 );
81     
82     bool  flag2 = IsPopOrder1(push, pop, nLength, nLength);
83     printf("Solution 2 is %d", flag2 );
84     return 0;
85 }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 關於偽共用的文章已經很多了,對於多線程編程來說,特別是多線程處理列表和數組的時候,要非常註意偽共用的問題。否則不僅無法發揮多線程的優勢,還可能比單線程性能還差。隨著JAVA版本的更新,再各個版本上減少偽共用的做法都有區別,一不小心代碼可能就失效了,要註意進行測試。這篇文章總結一下。 什麼是偽共用 關... ...
  • 前端JS代碼: var conditons = []; var test1 = new Object(); test1.name="1"; test1.id="2"; var test2 = new Object(); test2.name="1"; test2.id="2"; conditons. ...
  • 題目:輸入一個整數數組,判斷該數組是不是某二叉搜索樹的後序遍歷的結果。如果是則輸出Yes,否則輸出No。假設輸入的數組的任意兩個數字都互不相同。 思路:需要遍歷樹,二叉排序樹的特點是 lchild.key < root.key < rchild.key 那麼我們使用分治思想,先利用上面特點將左右子樹 ...
  • 作者:楓雪庭 出處:http://www.cnblogs.com/FengXueTing-px/ 歡迎轉載 Java學習心得之 HttpClient的GET和POST請求 1. 前言2. GET請求3. POST請求 一、前言 本篇博文記錄了HttpClient的GET和POST請求 本文內容基於以 ...
  • 很長時間以來一直代碼中用的比較多的數據列表主要是List,而且都是ArrayList,感覺有這個玩意就夠了。ArrayList是用於實現動態數組的包裝工具類,這樣寫代碼的時候就可以拉進拉出,迭代遍歷,蠻方便的。 也不知道從什麼時候開始慢慢的代碼中就經常會出現HashMap和HashSet之類的工具類 ...
  • 若在閱讀本片文章遇到許可權操作問題,請查看本系列的前兩章! http://www.cnblogs.com/CQ-LQJ/p/5609690.html和http://www.cnblogs.com/CQ-LQJ/p/5604331.html 現在步入正題,這篇文章是關於自有許可權管理系統設計的思路描述,自 ...
  • 題目:從上往下列印出二叉樹的每個結點,同一層的結點按照從左到右的順序列印。 思路:每一次列印一個結點的時候,如果該結點有子結點,則把該結點的子結點放到一個隊列的末尾。接下來到隊列的頭部取出最早進入隊列的結點,重覆前面的列印操作,直至隊列中所有的結點都被列印出來為止。 ...
  • 利用Python的os.walk()方法對文件目錄進行歷遍操作,得到文件目錄信息,方便下一步操作 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...