 
- C++ Library - Home
- C++ Library - <fstream>
- C++ Library - <iomanip>
- C++ Library - <ios>
- C++ Library - <iosfwd>
- C++ Library - <iostream>
- C++ Library - <istream>
- C++ Library - <ostream>
- C++ Library - <sstream>
- C++ Library - <streambuf>
- C++ Library - <atomic>
- C++ Library - <complex>
- C++ Library - <exception>
- C++ Library - <functional>
- C++ Library - <limits>
- C++ Library - <locale>
- C++ Library - <memory>
- C++ Library - <new>
- C++ Library - <numeric>
- C++ Library - <regex>
- C++ Library - <stdexcept>
- C++ Library - <string>
- C++ Library - <thread>
- C++ Library - <tuple>
- C++ Library - <typeinfo>
- C++ Library - <utility>
- C++ Library - <valarray>
- The C++ STL Library
- C++ Library - <array>
- C++ Library - <bitset>
- C++ Library - <deque>
- C++ Library - <forward_list>
- C++ Library - <list>
- C++ Library - <map>
- C++ Library - <multimap>
- C++ Library - <queue>
- C++ Library - <priority_queue>
- C++ Library - <set>
- C++ Library - <stack>
- C++ Library - <unordered_map>
- C++ Library - <unordered_set>
- C++ Library - <vector>
- C++ Library - <algorithm>
- C++ Library - <iterator>
- The C++ Advanced Library
- C++ Library - <any>
- C++ Library - <barrier>
- C++ Library - <bit>
- C++ Library - <chrono>
- C++ Library - <cinttypes>
- C++ Library - <clocale>
- C++ Library - <condition_variable>
- C++ Library - <coroutine>
- C++ Library - <cstdlib>
- C++ Library - <cstring>
- C++ Library - <cuchar>
- C++ Library - <charconv>
- C++ Library - <cfenv>
- C++ Library - <cmath>
- C++ Library - <ccomplex>
- C++ Library - <expected>
- C++ Library - <format>
- C++ Library - <future>
- C++ Library - <flat_set>
- C++ Library - <flat_map>
- C++ Library - <filesystem>
- C++ Library - <generator>
- C++ Library - <initializer_list>
- C++ Library - <latch>
- C++ Library - <memory_resource>
- C++ Library - <mutex>
- C++ Library - <mdspan>
- C++ Library - <optional>
- C++ Library - <print>
- C++ Library - <ratio>
- C++ Library - <scoped_allocator>
- C++ Library - <semaphore>
- C++ Library - <source_location>
- C++ Library - <span>
- C++ Library - <spanstream>
- C++ Library - <stacktrace>
- C++ Library - <stop_token>
- C++ Library - <syncstream>
- C++ Library - <system_error>
- C++ Library - <string_view>
- C++ Library - <stdatomic>
- C++ Library - <variant>
- C++ STL Library Cheat Sheet
- C++ STL - Cheat Sheet
- C++ Programming Resources
- C++ Programming Tutorial
- C++ Useful Resources
- C++ Discussion
C++ Stack::operator> Function
In C++, Stacks provide a flexible toolset for managing date in a LIFO(Last-In-First-Out) manner, meaning that the last added element will be removed first. one of the essential function is std::stack::operator> is used to compare two stacks. It evaluates if one stack is greater than another based on their contents, helping in sirting or prioritization tasks.
Syntax
Following is the Syntax for std::stack::operator> function −
bool operator>(const stack <Type, Container>& left, const stack <Type, Container>& right);
Parameters
- left − An object of type stack.
- right − An object of type stack.
Return value
It returns true if the stack on the left side of the operator is greaterthan the stack on the rightside, otherwise false.
Example 1
Let's look at the following where we are going to compare the contents of the two stacks.
#include <iostream>
#include <stack>
int main(){
   std::stack<int> x, y;
   x.push(2);
   x.push(4);
   x.push(6);
   y.push(1);
   y.push(3);
   y.push(5);
   if (x > y) {
      std::cout << "TRUE" << std::endl;
   } else {
      std::cout << "FALSE" << std::endl;
   }
   return 0;
}
Output
Let us compile and run the above program, this will produce the following result −
TRUE
Example 2
Considering the following example, where we are going to compare the size of the two stacks.
#include <iostream>
#include <stack>
int main(){
   std::stack<int> a, b;
   a.push(2);
   a.push(4);
   b.push(1);
   b.push(3);
   b.push(5);
   if (a.size() > b.size()) {
      std::cout << "a is greaterthan b";
   } else {
      std::cout << "a is not greaterthan b";
   }
   return 0;
}
Output
If we run the above code it will generate the following output −
a is not greaterthan b
Example 3
In the following example, we are going to see the usage of the std::stack::operator> function.
#include <iostream>
#include <stack>
using namespace std;
int main(void){
   stack<int> s1;
   stack<int> s2;
   for (int i = 0; i < 5; ++i) {
      s1.push(i + 1);
      s2.push(i + 1);
   }
   s1.push(6);
   if (s1 > s2)
      cout << "Stack s1 is greater than s2." << endl;
   s2.push(7);
   if (!(s1 > s2))
      cout << "Stack s1 is not greater than s2." << endl;
   return 0;
}
Output
Output of the above code is as follows −
Stack s1 is greater than s2. Stack s1 is not greater than s2.