题目: 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();
}
};