[WPS筆試題]實現棧的push,pop,max且時間復雜度為O(1)

今天做了一下WPS的筆試題,遇到了一道關于棧的題,覺得挺有意思的,就寫篇博客分享一下吧~~

題目要求:要求實現棧的數據結構,在該類型中實現一個能夠得到棧的最大元素的max函數,在該棧中,調用max,push,pop的時間復雜度是O(1).

解題思路:我們首先會想到的大概是,找最大元素不就排個序,直接取棧頂的元素不就好了嗎。可是這時,我們就把這個入棧的順序修改了。這并不是我們想要的。在不改變入棧順序的情況下,我們只能用一個輔助棧來解決這一類問題。

此時,我們可以將最大的元素放到這個輔助棧中,取輔助棧的棧頂元素就ok了。問題來了?

如何給輔助棧中放最大元素???

這里分為以下幾種情況:

  1. 我們先往數據棧中放元素,當輔助棧為空時,直接將數據棧中的元素放入輔助棧中
  2. 當輔助棧中有數據時,我們需要比較將要入棧的數據是否大于當前輔助棧中的數據,如果大于則繼續往輔助棧中放數據,否則放入當前輔助棧中的數據(這里用的比較巧妙,是為了尋找次大的數據,當pop出數據后,仍然可以找到次大的數據

最終解題思路

這里寫圖片描述

代碼實現

由于自己考慮到了string類的特殊情況,里邊還使用了仿函數的形式,實現了簡單的模板類。
#include<iostream>
using namespace std;
#include<stack>
#include<assert.h>
#include<string>template<class T>
struct Less
{bool operator()(const T& left,const T& right){return left < right;}
};template<class T>
struct Greater
{bool operator()(const T& left,const T& right){return left >= right;}
};template<class T,class Compare>
class StackWithMax
{
public:void Push(const T& data);void Pop();T& MaxValue();private:stack<T> value_st;stack<T> max_st;
};template<class T,class Compare>
void StackWithMax<T,Compare>::Push(const T& data)
{value_st.push(data);if(max_st.size() == 0 || Compare()(data,max_st.top()))max_st.push(data);elsemax_st.push(max_st.top());
}template<class T,class Compare>
void StackWithMax<T,Compare>::Pop()
{assert(value_st.size() >= 0 && max_st.size() >= 0);max_st.pop();value_st.pop();
}
template<class T,class Compare>
T& StackWithMax<T,Compare>::MaxValue()
{assert(value_st.size() >= 0 && max_st.size() >= 0);return max_st.top();
}

測試代碼

int main()
{StackWithMax<int,Greater<int>> st;st.Push(3);st.Push(4);st.Push(2);st.Push(1);st.Push(4);cout<<st.MaxValue()<<endl;st.Pop();cout<<st.MaxValue()<<endl;StackWithMax<string,Greater<string>> st1;st1.Push("aaa");st1.Push("bbb");st1.Push("ccc");st1.Push("fff");st1.Push("eee");cout<<st1.MaxValue()<<endl;st1.Pop();cout<<st1.MaxValue()<<endl;return 0;
}

運行結果

這里寫圖片描述

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/382743.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/382743.shtml
英文地址,請注明出處:http://en.pswp.cn/news/382743.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

MarkDown生成目錄索引

123 在第一行開頭寫[TOC] 必須是第一行&#xff0c;不可以在前面加別的東西。 1 2 3

ubuntu 如何用root身份進行登錄

公司有個小項目, 需要用python調用 sh腳本來執行一些東西, 執行腳本的時候需要輸入密碼 類似 sudo S paaswd 腳本, 但是給客戶部署的話, 再讓客戶客戶 保存密碼到配置文件, 就顯得麻煩, 就想到用root方式去登陸系統, 結果用了網上的方法, 還是登陸不進去, 最后結合簡書的一個方…

[劍指Offer]替換空格

今天看題的時候&#xff0c;遇到一個替換空格的題目&#xff0c;分析一下哈。 題目要求&#xff1a;把字符串中的每個空格替換成“%20”。例如輸入“we are happy”&#xff0c;則輸出“we%20are%20happy”。 解題思路&#xff1a;我們首先想到的是&#xff1a;移位思想。遇到…

C語言關鍵字 ISO/ANSI C90 C99 C11

面試考點 https://blog.csdn.net/csdn_kou/article/details/81113215 * 有的常用的我們都不知道是關鍵字&#xff0c;比如sizeof.這是面試中的考點&#xff0c;要注意。 * 同時當回答C語言中有多少關鍵字時&#xff0c;要回答前題條件&#xff0c;時針對哪一個版本

vm15 安裝 mac虛擬機的過程 轉載的

https://blog.csdn.net/weixin_43299649/article/details/82881567

task_struct解析

task_struct是Linux內核的一種數據結構&#xff0c;它用task_struct結構體來描述進程的信息。下面來剖析一下進程中保存的主要的信息有哪些&#xff1f; struct task_struct {//進程的運行時狀態volatile long state; /* -1 unrunnable, 0 runnable, >0 stopped */void …

ubuntu上有個小項目 ,需要調用xx.sh腳本, 出現無法識別 某些環境變量的解決辦法,僅供參考

項目是用python 調用 同事寫好的 xx.sh腳本&#xff0c; 在手動調用的時候 發現能正常調用&#xff0c; 當用python代碼的時候&#xff0c; 就不行了&#xff0c; 通過日志發現&#xff0c; python調用的時候 不識別 ADNROID_NDK這個環境變量&#xff0c; 在python中 我是通過&…

關于sudo

之前&#xff0c;我們使用sudo的時候&#xff0c;是因為其用戶本身具有root權限&#xff0c;所以可以sudo后執行相關操作&#xff0c;但是對于普通用戶來說&#xff0c;它是既不具有sudo權限&#xff0c;又不在sudo用戶組中&#xff0c;那么我們來研究一下如何將新創建的用戶添…

在使用 python 封裝的進程池 from concurrent.futures import ProcessPoolExecutor 遇到的問題

在ubuntu中&#xff0c;用的是python3.5 executeprebuildpath ExecutePrebuild()processpool ProcessPoolExecutor(1)processpool.submit(executeprebuildpath.run).add_done_callback(self.precallback)processpool.shutdown(waitFalse)self.runsign Trueself.runningprebu…

對pthread_create未定義的引用

pthread庫不是Linux系統默認的庫&#xff0c;連接時需要使用庫libpthread.a,在編譯中要加-lpthread [koulocalhost practive]$ gcc creat.c /tmp/ccPULtaF.o&#xff1a;在函數‘main’中&#xff1a; creat.c:(.text0x58)&#xff1a;對‘pthread_create’未定義的引用 coll…

Bash入門

Bash簡介&#xff1a; Bash&#xff08;GNU Bourne-Again Shell&#xff09;是一個為GNU計劃編寫的Unix shell&#xff0c;它是許多Linux平臺默認使用的shell。 shell是一個命令解釋器&#xff0c;是介于操作系統內核與用戶之間的一個絕緣層。準確地說&#xff0c;它也是能力…

ubuntu 設置分辨率 親測可用 轉載的

網上試了很多方法, 這家管用 https://blog.csdn.net/qq_35661436/article/details/72802040

線程之售票系統pthread_mutex,_lock,_unlock

先看一下這篇文章 https://blog.csdn.net/csdn_kou/article/details/81148268 四個人同時買票票&#xff0c;引出線程 #include "head.h" int ticket 100; void * route(void *arg) {char *id (char *)arg;while(1){if(ticket>0){usleep(1000);printf("…

Bash基本語法

1. 變量賦值 a375 hello$a 這里需要注意的是&#xff0c;等號兩邊不能有空格 還有一個例子是這樣的 例1&#xff1a; 結果為&#xff1a; 關于上述&#xff0c;主要有如下幾點&#xff1a; $hello和${hello}是一樣的&#xff0c;在bash中如果遇到空格&#xff0c;tab鍵時&a…

windows下 , py運用了 進程池, 將py打包成exe,出現錯誤的 解決思路之一

在windows上,用pycharm開發了一個小項目, 用到了from concurrent.futures import ProcessPoolExecutor 本來在pycharm里面,運行的好好地, 可是打包成exe的時候, 發現 當程序運行到 進程池執行任務的時候,會創建一個新的界面, 猜測應該是創建了一個新的進程, 百度后,發現在 程序…

關于fd和fp(fd:file descirptor fp:file pointor)

通常&#xff0c;我們在輸入數據或輸出數據的設備為鍵盤或者顯示器。當然&#xff0c;我們比較熟悉的輸入輸出&#xff0c;可能就是對于文件的操作&#xff0c;還有直接從終端輸出&#xff0c;顯示到顯示器上。在C語言中&#xff0c;我們使用fopen,fclose,fread,fwrite對文件進…

粗談pragma once與 #ifndef的區別

#ifnde不受編譯器的任何限制&#xff1b; #pragma once不受一些較老的編譯器支持&#xff0c;兼容性不夠好

在mac os10.13系統下 ,將py文件打包成可執行程序后, 里面的路徑出現的問題

本來 用命令行運行py文件, 代碼里面 獲取當前路徑的 語句 例如: os.getcwd() os.path.abspath(__file__) os.path.realpath(__file__)都可以獲取到當前文件的路徑, 但是打包成 可執行程序后, 統統不對了, 變成了 類似 /usr/xxx 的路徑 https://stackoverflow.com/questions/50…

[linux]wait詳解

wait&#xff1a;進程等待 主要有兩種等待方式&#xff1a;阻塞式等待和非阻塞式等待 阻塞式等待&#xff1a;如果子進程正在運行&#xff0c;父進程將會一直等待著子進程運行結束&#xff0c;并且自己什么事都不干 非阻塞式等待&#xff1a;如果子進程正在運行&#xff0c;…