155. Min Stack
admin
2024-02-06 15:02:28
0

题目名称

  1. Min Stack

题目描述

Design a stack that supports push, pop, top, and retrieving the minimum element in constant time.

Implement the MinStack class:

MinStack() initializes the stack object.
void push(int val) pushes the element val onto the stack.
void pop() removes the element on the top of the stack.
int top() gets the top element of the stack.
int getMin() retrieves the minimum element in the stack.
You must implement a solution with O(1) time complexity for each function.

初试思路

获取最小值时,如果在获取时再遍历栈找到最小值是很慢的,所以在push和pop的时候保持最小值的动态更新。

初试代码

// 我的代码
class MinStack {
public:vector > a;MinStack() {}void push(int val) {if(isEmpty()){a.push_back({val, val});}else{a.push_back({val, min(val, a.back().second)});                                             }}void pop() {if(!isEmpty()){a.pop_back();  }}int top() {if(!isEmpty()){return a.back().first; }return 0;}int getMin() {if(!isEmpty()){return a.back().second;  }return 0;        }bool isEmpty(){ //这个函数也可以直接用vector的a.empty()代替cout<<(a.size()==0)<push(val);* obj->pop();* int param_3 = obj->top();* int param_4 = obj->getMin();*/

学到了啥

一、capacity相关函数

1.size:size_type size() const;

容器中元素个数。c.size();

2.max_size():size_type max_size() const;

返回最大容量。c.maxsize();

3.resize:void resize (size_type n, value_type val = value_type());

改变容器可以容纳元素的个数为n。如果n小于当前的容器大小,则保留前面n个元素,移除后面的。如果n大于当前容器大小,就扩展容器。value是初始值,如果n大于当前容器大小,则新增加的元素的值为value,若value省略,会自动调用一个默认值。

std::vector c;

for(int i=0;i<10;i++)

 c.push_back(i);

c.resize(5);

c.resize(8,10);

c.resize(12);

for(int i=0;i

std::cout<

结果为:1 2 3 4 5 10 10 10 0 0 0 0

4.capacity:size_type capacity() const;

当前分配给容器的存储空间大小(元素个数),这并不限制容器的扩展,理论限制容器扩展大小是max_size的值

5.empty:bool empty() const;

返回容器是否为空while(!c.empty()){sum+=c.back();
c.pop_back();}

6.reserve:void reserve (size_type n);

使得capacity至少能容纳n个元素。

7.shrink_to_fit(C++11):void shrink_to_fit();

减小capacity,使其与容器大小相同

四、元素访问相关函数

1.[ ]操作:获取特定位置的元素。c[i];

2.at:reference at (size_type n);

   const_reference at (size_type n) const;

返回位置n处的元素。c.at(i),与c[i]差不多

3.front:reference front();

           const_reference front() const;

返回容器中的第一个元素。c.front();

4.back:reference back()

    const_reference back() const;

返回容器中最后一个元素。c.back();

5.data(C++11):value_type* data() noexcept;

       const value_type* data() const noexcept;

返回一个指向容器中数组的指针c.data()

int *p=c.data();

*p=10;

++p;

*p=20;

p[2]=100;

则c中存储的前面三个数据为10、20、100

五、更新操作

1.assign:template void assign (InputIterator first, InputIterator last);

           void assign (size_type n, const value_type& val);void assign (initializer_list il);(C++11)

给容器分配新的内容,并替换当前内容,同时修改大小,val为初始值

std::vectorfirst;

std::vectorsecond;

std::vectorthird;

first.assign(7,100);

std::vector::iterator it;

it=first.begin()+1;

second.assign(it,first.end()-1);

int myints[]={1776,7,4};

third.assign(myints,myints+3);

std::cout<

结果为:7 5 3

2.push_back: void push_back (const value_type& val);

在容器最后增加一个新的元素。c.push_back(n)

3.pop_back:void pop_back();

移除最后一个元素。c.pop_back()

4.insert:iterator insert(iterator position,const value_type& val):在position处插入元素val

         void insert(iterator position,size_type n,const value_type& val):在position处插入n个元素,插入的元素值初始化为valvoid insert(iterator position,InputIterator first,InputIterator last):在position处插入数组中从first到last的元素

vector c(3,100);

vector::iterator it;

it=c.begin();

it=c.insert(it,200);

c.insert(it,2,300);

it=c.begin();

vector d(2,400);

c.insert(it+2,d.begin(),d.end());

int s[]={501,502,503};

c.insert(c.begin(),s,s+3);

此时c中元素为:501 502 503 300 300 400 400 200 100 100 100

5.erase:iterator erase(iterator position):删除position处的元素

         iterator erase(iterator first,iterator last):删除first到last的元素

相关内容

热门资讯

安卓版pc端系统,跨越平台界限... 你有没有想过,你的安卓手机里的应用,竟然可以在电脑上无缝运行?没错,这就是安卓版PC端系统的魅力所在...
安卓7车机系统,科技与安全的完... 你有没有发现,现在的汽车越来越智能了?没错,我说的就是那些内置了安卓7车机系统的家伙们。想象当你坐在...
王者荣耀安卓系统区别,深度揭秘... 你有没有发现,玩王者荣耀的时候,安卓系统的手机和苹果系统的手机,感觉就像是两个不同的世界呢?今天,就...
盒子电视安卓9系统,畅享智能新... 亲爱的读者们,你是否曾为拥有一台功能强大、系统流畅的电视而心动?今天,我要给你介绍一款特别受欢迎的盒...
智慧吴江app安卓系统,安卓系... 你知道吗?最近吴江地区掀起了一股智慧风潮,一款名为“智慧吴江app”的应用在安卓系统上大受欢迎。这款...
苹果系统听歌app安卓,跨平台... 你有没有发现,无论是走在街头还是坐在家里,音乐总是能瞬间点燃我们的心情?而在这个音乐无处不在的时代,...
安卓系统卡顿根源,性能瓶颈与优... 手机用久了是不是感觉越来越卡?是不是每次打开应用都要等半天,甚至有时候直接卡死?别急,今天就来跟你聊...
电脑系统怎么装安卓系统,电脑系... 你有没有想过,把安卓系统装在你的电脑上,是不是就像给电脑穿上了时尚的新衣呢?想象你可以在电脑上直接使...
安卓系统华为手环app,健康管... 你有没有发现,现在的生活越来越离不开智能设备了?手机、平板、手表……这些小玩意儿不仅让我们的生活变得...
switch lite刷安卓系... 你有没有想过,你的Switch Lite除了玩那些可爱的任天堂游戏,还能干些什么呢?没错,今天我要给...
想买华为但是安卓系统,尽享安卓... 最近是不是也被华为的新款手机给迷住了?看着那流畅的线条和强大的性能,是不是心动了呢?但是,一想到安卓...
怎么拷安卓系统文件,安卓系统文... 你有没有想过,手机里的那些安卓系统文件,其实就像是一扇通往手机世界的秘密通道呢?想要深入了解你的安卓...
安卓系统移植按键失灵,安卓系统... 最近你的安卓手机是不是也遇到了按键失灵的尴尬情况呢?这可真是让人头疼啊!别急,今天就来给你详细解析一...
安卓系统更新管理在哪,全面解析... 你有没有发现,你的安卓手机最近是不是总在提醒你更新系统呢?别急,别急,今天就来手把手教你,安卓系统更...
安卓系统哪里出的,从诞生地到全... 你有没有想过,我们每天离不开的安卓系统,它究竟是从哪里冒出来的呢?是不是觉得这个问题有点儿像是在问星...
最好的电脑安卓系统,最佳电脑安... 亲爱的电脑迷们,你是否在寻找一款既能满足你工作需求,又能让你畅享娱乐的电脑操作系统呢?今天,我要给你...
安卓系统保密性,守护隐私的坚实... 你知道吗?在这个信息爆炸的时代,保护个人隐私变得比以往任何时候都重要。尤其是对于安卓系统用户来说,了...
苹果系统下载安卓版本,安卓版本... 你有没有想过,为什么苹果系统的手机那么受欢迎,却还有人想要下载安卓版本呢?这背后可是有着不少故事呢!...
安卓系统如何下载carplay... 你是不是也和我一样,对安卓系统上的CarPlay功能充满了好奇?想象在安卓手机上就能享受到苹果Car...
退回安卓系统的理由,揭秘安卓系... 你有没有想过,为什么有些人会选择退回到安卓系统呢?这可不是一件简单的事情,背后可是有着不少原因哦!让...