 
- 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
The stack is a fundamental data structure that follows the LIFO(Last-In-First-Out) manner, meaning that the last added element will be removed first.
The C++ function std::stack::operator<= compares the two stacks, determining if the first stack is less than or equal to the second stack. It evaluates the stacks size and elements wise comparisons to determine the relationship.
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 return true if the stack on the leftside is lessthan or equal to stack on the right side, otherwise false.
Example 1
Let's look at the following where we are going to compare the elements inside the stack using the <= operator.
#include <iostream>
#include <stack>
int main(){
   std::stack<int> x;
   x.push(1);
   x.push(2);
   x.push(3);
   if (x.top() <= 5) {
      std::cout << "Elements are Lessthan Or Equal to 5";
   } else {
      std::cout << "Elements are Greaterthan 5";
   }
   return 0;
}
Output
Let us compile and run the above program, this will produce the following result −
Elements are Lessthan Or Equal to 5
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> x, y;
   x.push(11);
   x.push(25);
   y.push(16);
   if (x.size() <= y.size()) {
      std::cout << "X is Lessthan Or Equal To Y";
   } else {
      std::cout << "X Has More Elements Compared To Y";
   }
   return 0;
}
Output
If we run the above code it will generate the following output −
X Has More Elements Compared To Y
Example 3
In the following example, we are going to check if one stack is empty or lessthan or equal to another stack.
#include <iostream>
#include <stack>
int main(){
   std::stack<int> a, b;
   a.push(12);
   if (a.empty() || a <= b) {
      std::cout << "True";
   } else {
      std::cout << "False";
   }
   return 0;
}
Output
Output of the above code is as follows −
False