<stack> 演算子
operator!=
演算子の左辺のスタック オブジェクトが右辺のスタック オブジェクトと等しくないかどうかを調べます。
bool operator!=(const stack <Type, Container>& left, const stack <Type, Container>& right,);
パラメーター
left
stack 型のオブジェクト。
right
stack 型のオブジェクト。
戻り値
stack 同士が等しくない場合は true、stack 同士が等しい場合は false。
注釈
stack オブジェクト間の比較は、要素のペアの比較に基づいています。 2 つの stack は、同じ数の要素を持ち、各要素の値が同じである場合に等しくなります。 それ以外の場合は等しくありません。
例
// stack_op_me.cpp
// compile with: /EHsc
#include <stack>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
// Declares stacks with vector base containers
stack <int, vector<int> > s1, s2, s3;
// The following would have cause an error because stacks with
// different base containers are not equality comparable
// stack <int, list<int> > s3;
s1.push( 1 );
s2.push( 2 );
s3.push( 1 );
if ( s1 != s2 )
cout << "The stacks s1 and s2 are not equal." << endl;
else
cout << "The stacks s1 and s2 are equal." << endl;
if ( s1 != s3 )
cout << "The stacks s1 and s3 are not equal." << endl;
else
cout << "The stacks s1 and s3 are equal." << endl;
}
The stacks s1 and s2 are not equal.
The stacks s1 and s3 are equal.
operator<
演算子の左辺のスタック オブジェクトが右辺のスタック オブジェクトより小さいかどうかを調べます。
bool operator<(const stack <Type, Container>& left, const stack <Type, Container>& right);
パラメーター
left
stack 型のオブジェクト。
right
stack 型のオブジェクト。
戻り値
演算子の左辺の stack が演算子の右辺の stack 未満である場合は true、それ以外の場合は false。
注釈
stack オブジェクト間の比較は、要素のペアの比較に基づいています。 2 つの stack オブジェクト間の小なり関係は、最初の等しくない要素のペアの比較に基づいています。
例
// stack_op_lt.cpp
// compile with: /EHsc
#include <stack>
#include <list>
#include <iostream>
int main( )
{
using namespace std;
// Declares stacks with list base container
stack <int, list<int> > s1, s2, s3;
s1.push( 2 );
s1.push( 4 );
s1.push( 6 );
s1.push( 8 );
s2.push( 5 );
s2.push( 10 );
s3.push( 2 );
s3.push( 4 );
s3.push( 6 );
s3.push( 8 );
if ( s1 >= s2 )
cout << "The stack s1 is greater than or equal to "
<< "the stack s2." << endl;
else
cout << "The stack s1 is less than "
<< "the stack s2." << endl;
if ( s1>= s3 )
cout << "The stack s1 is greater than or equal to "
<< "the stack s3." << endl;
else
cout << "The stack s1 is less than "
<< "the stack s3." << endl;
// to print out the stack s1 ( by unstacking the elements):
stack <int>::size_type i_size_s1 = s1.size( );
cout << "The stack s1 from the top down is: ( ";
unsigned int i;
for ( i = 1 ; i <= i_size_s1 ; i++ )
{
cout << s1.top( ) << " ";
s1.pop( );
}
cout << ")." << endl;
}
The stack s1 is less than the stack s2.
The stack s1 is greater than or equal to the stack s3.
The stack s1 from the top down is: ( 8 6 4 2 ).
operator<=
演算子の左辺のスタック オブジェクトが右辺のスタック オブジェクト以下かどうかを調べます。
bool operator<=(const stack <Type, Container>& left, const stack <Type, Container>& right);
パラメーター
left
stack 型のオブジェクト。
right
stack 型のオブジェクト。
戻り値
演算子の左辺の stack が演算子の右辺の stack 以下である場合は true、それ以外の場合は false。
注釈
stack オブジェクト間の比較は、要素のペアの比較に基づいています。 2 つの stack オブジェクト間の "以下" 関係は、最初の等しくない要素のペアの比較に基づいています。
例
// stack_op_le.cpp
// compile with: /EHsc
#include <stack>
#include <iostream>
int main( )
{
using namespace std;
// Declares stacks with default deque base container
stack <int> s1, s2, s3;
s1.push( 5 );
s1.push( 10 );
s2.push( 1 );
s2.push( 2 );
s3.push( 5 );
s3.push( 10 );
if ( s1 <= s2 )
cout << "The stack s1 is less than or equal to "
<< "the stack s2." << endl;
else
cout << "The stack s1 is greater than "
<< "the stack s2." << endl;
if ( s1 <= s3 )
cout << "The stack s1 is less than or equal to "
<< "the stack s3." << endl;
else
cout << "The stack s1 is greater than "
<< "the stack s3." << endl;
}
The stack s1 is greater than the stack s2.
The stack s1 is less than or equal to the stack s3.
operator==
演算子の左辺のスタック オブジェクトが右辺のスタック オブジェクトと等しいかどうかを調べます。
bool operator==(const stack <Type, Container>& left, const stack <Type, Container>& right);
パラメーター
left
stack 型のオブジェクト。
right
stack 型のオブジェクト。
戻り値
stack 同士が等しい場合は true、stack 同士が等しくない場合は false。
注釈
stack オブジェクト間の比較は、要素のペアの比較に基づいています。 2 つの stack は、同じ数の要素を持ち、各要素の値が同じである場合に等しくなります。 それ以外の場合は等しくありません。
例
// stack_op_eq.cpp
// compile with: /EHsc
#include <stack>
#include <vector>
#include <iostream>
int main( )
{
using namespace std;
// Declares stacks with vector base containers
stack <int, vector<int> > s1, s2, s3;
// The following would have cause an error because stacks with
// different base containers are not equality comparable
// stack <int, list<int> > s3;
s1.push( 1 );
s2.push( 2 );
s3.push( 1 );
if ( s1 == s2 )
cout << "The stacks s1 and s2 are equal." << endl;
else
cout << "The stacks s1 and s2 are not equal." << endl;
if ( s1 == s3 )
cout << "The stacks s1 and s3 are equal." << endl;
else
cout << "The stacks s1 and s3 are not equal." << endl;
}
The stacks s1 and s2 are not equal.
The stacks s1 and s3 are equal.
operator>
演算子の左辺のスタック オブジェクトが右辺のスタック オブジェクトより大きいかどうかを調べます。
bool operator>(const stack <Type, Container>& left, const stack <Type, Container>& right);
パラメーター
left
stack 型のオブジェクト。
right
stack 型のオブジェクト。
戻り値
演算子の左辺の stack が演算子の右辺の stack より大きい場合は true、それ以外の場合は false。
注釈
stack オブジェクト間の比較は、要素のペアの比較に基づいています。 2 つの stack オブジェクト間の大なり関係は、最初の等しくない要素のペアの比較に基づいています。
例
// stack_op_gt.cpp
// compile with: /EHsc
#include <stack>
#include <list>
#include <iostream>
int main( )
{
using namespace std;
// Declares stacks with list base container
stack <int, list<int> > s1, s2, s3;
s1.push( 1 );
s1.push( 2 );
s1.push( 3 );
s2.push( 5 );
s2.push( 10 );
s3.push( 1 );
s3.push( 2 );
if ( s1 > s2 )
cout << "The stack s1 is greater than "
<< "the stack s2." << endl;
else
cout << "The stack s1 is not greater than "
<< "the stack s2." << endl;
if ( s1> s3 )
cout << "The stack s1 is greater than "
<< "the stack s3." << endl;
else
cout << "The stack s1 is not greater than "
<< "the stack s3." << endl;
}
The stack s1 is not greater than the stack s2.
The stack s1 is greater than the stack s3.
operator>=
演算子の左辺のスタック オブジェクトが右辺のスタック オブジェクト以上かどうかを調べます。
bool operator>=(const stack <Type, Container>& left, const stack <Type, Container>& right);
パラメーター
left
stack 型のオブジェクト。
right
stack 型のオブジェクト。
戻り値
演算子の左辺の stack が演算子の右辺の stack より厳密に小さい場合は true、それ以外の場合は false。
注釈
stack オブジェクト間の比較は、要素のペアの比較に基づいています。 2 つの stack オブジェクト間の "以上" 関係は、最初の等しくない要素のペアの比較に基づいています。
例
// stack_op_ge.cpp
// compile with: /EHsc
#include <stack>
#include <list>
#include <iostream>
int main( )
{
using namespace std;
// Declares stacks with list base container
stack <int, list<int> > s1, s2, s3;
s1.push( 1 );
s1.push( 2 );
s2.push( 5 );
s2.push( 10 );
s3.push( 1 );
s3.push( 2 );
if ( s1 >= s2 )
cout << "The stack s1 is greater than or equal to "
<< "the stack s2." << endl;
else
cout << "The stack s1 is less than "
<< "the stack s2." << endl;
if ( s1>= s3 )
cout << "The stack s1 is greater than or equal to "
<< "the stack s3." << endl;
else
cout << "The stack s1 is less than "
<< "the stack s3." << endl;
}
The stack s1 is less than the stack s2.
The stack s1 is greater than or equal to the stack s3.