- C 标准库
- C 标准库
- C++ 标准库
- C++ 库 - 首页
- C++ 库 - <fstream>
- C++ 库 - <iomanip>
- C++ 库 - <ios>
- C++ 库 - <iosfwd>
- C++ 库 - <iostream>
- C++ 库 - <istream>
- C++ 库 - <ostream>
- C++ 库 - <sstream>
- C++ 库 - <streambuf>
- C++ 库 - <atomic>
- C++ 库 - <complex>
- C++ 库 - <exception>
- C++ 库 - <functional>
- C++ 库 - <limits>
- C++ 库 - <locale>
- C++ 库 - <memory>
- C++ 库 - <new>
- C++ 库 - <numeric>
- C++ 库 - <regex>
- C++ 库 - <stdexcept>
- C++ 库 - <string>
- C++ 库 - <thread>
- C++ 库 - <tuple>
- C++ 库 - <typeinfo>
- C++ 库 - <utility>
- C++ 库 - <valarray>
- C++ STL 库
- C++ 库 - <array>
- C++ 库 - <bitset>
- C++ 库 - <deque>
- C++ 库 - <forward_list>
- C++ 库 - <list>
- C++ 库 - <map>
- C++ 库 - <multimap>
- C++ 库 - <queue>
- C++ 库 - <priority_queue>
- C++ 库 - <set>
- C++ 库 - <stack>
- C++ 库 - <unordered_map>
- C++ 库 - <unordered_set>
- C++ 库 - <vector>
- C++ 库 - <algorithm>
- C++ 库 - <iterator>
- C++ 高级库
- C++ 库 - <any>
- C++ 库 - <barrier>
- C++ 库 - <bit>
- C++ 库 - <chrono>
- C++ 库 - <cinttypes>
- C++ 库 - <clocale>
- C++ 库 - <condition_variable>
- C++ 库 - <coroutine>
- C++ 库 - <cstdlib>
- C++ 库 - <cstring>
- C++ 库 - <cuchar>
- C++ 库 - <charconv>
- C++ 库 - <cfenv>
- C++ 库 - <cmath>
- C++ 库 - <ccomplex>
- C++ 库 - <expected>
- C++ 库 - <format>
- C++ 库 - <future>
- C++ 库 - <flat_set>
- C++ 库 - <flat_map>
- C++ 库 - <filesystem>
- C++ 库 - <generator>
- C++ 库 - <initializer_list>
- C++ 库 - <latch>
- C++ 库 - <memory_resource>
- C++ 库 - <mutex>
- C++ 库 - <mdspan>
- C++ 库 - <optional>
- C++ 库 - <print>
- C++ 库 - <ratio>
- C++ 库 - <scoped_allocator>
- C++ 库 - <semaphore>
- C++ 库 - <source_location>
- C++ 库 - <span>
- C++ 库 - <spanstream>
- C++ 库 - <stacktrace>
- C++ 库 - <stop_token>
- C++ 库 - <syncstream>
- C++ 库 - <system_error>
- C++ 库 - <string_view>
- C++ 库 - <stdatomic>
- C++ 库 - <variant>
- C++ STL 库速查表
- C++ STL - 速查表
C++ Stack::operator< 函数
C++ 函数std::stack::operator<是一个二元运算符,用于检查第一个栈是否小于另一个栈。
此函数不接受任何参数,如果第一个栈小于另一个栈,则返回布尔值 true,否则返回 false。
为类定义 operator< 函数时,务必确保它对类中的对象提供严格的弱排序。这意味着该函数必须满足三个属性:自反性(一个对象不大于自身),反对称性(如果 A < B 则 !(B < A)),以及传递性(如果 A < B 且 B < C,则 A < C)。
二元运算符采用两个操作数来执行特定的操作,例如加法、减法、乘法、除法或比较。它由符号或关键字表示,例如 +、-、*、/ 和 !=。
语法
以下是 std::stack::operator< 的语法:
bool stack1 < stack2
参数
- stack1 - 第一个栈。
- stack2 - 第二个栈。
返回值
如果第一个栈小于第二个栈,则返回 true,否则返回 false。
示例 1
以下示例演示了如何通过比较两个大小相同的栈来使用 std::stack::operator< 函数。
首先,我们创建两个栈 's1' 和 's2',并将元素 '1 - 5' 插入到两个栈中。然后,我们使用 operator< 函数对它们进行比较。
#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); } if (s1 < s2){ cout << "Stack s1 is less than s2." << endl;} else { cout << "Stack s1 is not less than s2." << endl; } return 0; }
输出
让我们编译并运行上述程序,这将产生以下结果:
Stack s1 is not less than s2.
示例 2
在这里,我们创建两个栈 's1' 和 's2',然后使用 operator< 函数根据它们的顶部元素对它们进行比较。
#include <iostream> #include <stack> using namespace std; int main(void) { stack<int> s1; s1.push(1); s1.push(2); s1.push(3); stack<int> s2; s2.push(1); s2.push(5); if (s1.top() < s2.top()) { cout << "s1 is smaller than s2\n"; } else { cout << "s1 is not smaller than s2\n"; } }
输出
如果我们运行上述代码,它将生成以下输出:
s1 is smaller than s2
示例 3
在以下示例中,我们定义了一个函数 'getMinElement',它接受一个整数栈的引用作为输入,并使用另一个栈返回栈中的最小元素。然后,我们在主函数中创建一个整数栈 's',并将三个值压入其中,并调用 'getMinElement' 函数获取 's' 中的最小元素。
#include <iostream> #include <stack> using namespace std; int getMinElement(stack<int>& s) { stack<int> minStack; while (!s.empty()) { int current = s.top(); s.pop(); if (minStack.empty() || current < minStack.top()) { minStack.push(current); } else { minStack.push(minStack.top()); } } int minElement = minStack.top(); while (!minStack.empty()) { minStack.pop(); } return minElement; } int main() { stack<int> s; // populate s s.push(48); s.push(2); s.push(103); // get minimum element in s using another stack int minElement = getMinElement(s); cout << "Minimum element in s is " << minElement << endl; return 0; }
输出
以下是上述代码的输出:
Minimum element in s is 2
广告