leetcode 面试题03.02 栈的最小值

题目: https://leetcode-cn.com/problems/min-stack-lcci/

思路一:利用c++的pair对象,每次进栈的时候都将目标值和最小值进行压栈, 1.用pair压栈两个数,一个是正常元素,另一个是目前最小值
C++ pair的用法实例详解
1 pair的应用
pair是将2个数据组合成一个数据,当需要这样的需求时就可以使用pair,如stl中的map就是将key和value放在一起来保存。另一个应用是,当一个函数需要返回2个数据的时候,可以选择pair。 pair的实现是一个结构体,主要的两个成员变量是first second 因为是使用struct不是class,所以可以直接使用pair的成员变量。
2 make_pair函数

1

template pair make_pair(T1 a, T2 b) { return pair(a, b); }
很明显,我们可以使用pair的构造函数也可以使用make_pair来生成我们需要的pair。 一般make_pair都使用在需要pair做参数的位置,可以直接调用make_pair生成pair对象很方便,代码也很清晰。 另一个使用的方面就是pair可以接受隐式的类型转换,这样可以获得更高的灵活度。灵活度也带来了一些问题如:

1
2
3

std::pair< int , float >(1, 1.1);

std::make_pair(1, 1.1);
是不同的,第一个就是float,而第2个会自己匹配成double。
类模板:template <class T1, class T2> struct pair
参数:T1是第一个值的数据类型,T2是第二个值的数据类型。
功能:pair将一对值组合成一个值,这一对值可以具有不同的数据类型(T1和T2),两个值可以分别用pair的两个公有函数first和second访问。
具体用法:
1.定义(构造):

1
2
3

pair< int , double > p1; //使用默认构造函数
pair< int , double > p2(1, 2.4); //用给定值初始化
pair< int , double > p3(p2); //拷贝构造函数
2.访问两个元素(通过first和second):

1
2
3
4

pair< int , double > p1; //使用默认构造函数
p1.first = 1;
p1.second = 2.5;
cout << p1.first << ’ ’ << p1.second << endl;
输出结果:1 2.5
3.赋值operator = :
(1)利用make_pair:

1
2

pair< int , double > p1;
p1 = make_pair(1, 1.2);
(2)变量间赋值:

1
2

pair< int , double > p1(1, 1.2);
pair< int , double > p2 = p1;
Pair类型概述
pair是一种模板类型,其中包含两个数据值,两个数据的类型可以不同,基本的定义如下:

1

pair< int , string> a;
表示a中有两个类型,第一个元素是int型的,第二个元素是string类型的,如果创建pair的时候没有对其进行初始化,则调用默认构造函数对其初始化。

1

pair<string, string> a( “James” , “Joy” );
也可以像上面一样在定义的时候直接对其初始化。
由于pair类型的使用比较繁琐,因为如果要定义多个形同的pair类型的时候,可以时候typedef简化声明:

1
2
3

typedef pair<string, string> author;
author pro( “May” , “Lily” );
author joye( “James” , “Joyce” );
Pair对象的操作
对于pair类,由于它只有两个元素,分别名为first和second,因此直接使用普通的点操作符即可访问其成员

1
2
3

pair<string, string> a( “Lily” , “Poly” );
string name;
name = pair.second;
生成新的pair对象
可以使用make_pair对已存在的两个数据构造一个新的pair类型:

1
2
3
4

int a = 8;
string m = “James” ;
pair< int , string> newone;
newone = make_pair(a, m);

class MinStack {
public:
/** initialize your data structure here. */
stack<pair<int,int>>stk;

MinStack() {

}


void push(int x) {
 if(stk.empty)
 stk.push(make_pair(x,x))
 else
 stk.push(make_pair(x, min(x, stk.top().second)));
}

void pop() {
   stk.pop();

}

int top() {
    int val=stk.top().first;
    return val;

}

int getMin() {

     int val=stk.top().second;
     return val;
}

};

思路二:双栈
一个栈正常入栈,一个栈将最小值入栈,
class MinStack {
public:
stack stk1,stk2;
MinStack() {

}
void push(int x) {

    stk1.push(x);
    if(stk2.empty())
    {
       stk2.push(x);
    }
    else{

     
       stk2.push(min(x,stk1.top()));  
    }
 
}
void pop() {
    stk1.pop();
    stk2.pop();
}
int top() {
    return stk1.top();
 
}
int getMin() {
    return stk2.top();
}

};

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值