C++ std operator<函数
**Operator < ** 是 C++ 中 set 的一个非成员重载函数。这个函数被用来检查第一个 set 是否小于其他 set。
注意:Operator < 会按顺序比较 set 的元素,并在第一次不匹配时停止比较。
语法
template <class T, class Compare, class Alloc>
bool operator< ( const set<T,Compare,Alloc>& lhs,
const set<T,Compare,Alloc>& rhs );
参数
lhs :第一个集合对象。
rhs :第二个集合对象。
返回值
如果集合对象的左侧小于右侧,则返回true;否则返回false。
复杂度
如果lhs和rhs的大小不同,则复杂度为常数。
否则,复杂度将与lhs和rhs的大小线性相关。
迭代器的有效性
没有变化。
数据竞争
容器、lhs和rhs都被访问。
同时访问未修改的集合元素始终是安全的。
异常安全性
该函数不会抛出异常。
示例1
让我们看一个简单的示例来检查第一个集合是否小于第二个集合:
#include <iostream>
#include <set>
using namespace std;
int main() {
set<char> m1;
set<char> m2;
m2.emplace('a');
if (m1 < m2)
cout << "Set m1 is less than m2." << endl;
m1 = m2;
if (!(m1 < m2))
cout << "Set m1 is not less than m2." << endl;
return 0;
}
输出:
Set m1 is less than m2.
Set m1 is not less than m2.
在上面的示例中,有两个集合m1和m2。m2包含一个元素,m1为空。当我们比较这两个集合时,会显示消息“集合m1小于m2”,然后将m2赋值给m1,两个集合中都有相等的元素,然后会显示消息“集合m1不小于m2”。
示例2
让我们看一个简单的示例:
#include <set>
#include <iostream>
int main ()
{
using namespace std;
set <int> m1, m2, m3;
int i;
for (i = 1; i <3; i ++)
{
m1.insert (i);
m2.insert (i * i);
m3.insert (i - 1);
}
if (m1 <m2)
cout << "The set m1 is less than the set m2." << endl;
else
cout << "The set m1 is not less than the set m2." << endl;
if (m1 <m3)
cout << "The set m1 is less than the set m3." << endl;
else
cout << "The set m1 is not less than the set m3." << endl;
}
输出:
The set m1 is less than the set m2.
The set m1 is not less than the set m3.
示例3
让我们看一个简单的示例:
#include <iostream>
#include <set>
using namespace std;
int main()
{
set<int> s1, s2;
s1.insert(10);
s1.insert(20);
s1.insert(30);
s2 = s1;
cout << (s1 < s2) << endl;
s2.insert(40);
cout << (s1 < s2) << endl;
}
输出:
0
1
在上面的示例中,如果设置s1小于s2,则返回1,否则返回0。
示例4
#include <set>
#include <iostream>
using namespace std;
int main ()
{
set<string> m2;
typedef set<string> login;
m2.insert("xyz@123") ; //stored password
string password;
login m1;
cout<<"---------Login----------"<<endl<<endl;
cout<<"Enter the password: \n";
cin>> password; // Get value
m1.insert(password); // Put them in set
cout<<"Password you have entered: \n";
for (auto it = m1.begin(); it != m1.end(); it++) {
cout << (*it)<< endl;
}
cout<<"Password stored in the system :\n";
for (auto it = m2.begin(); it != m2.end(); it++) {
cout << (*it)<< endl;
}
if (m1 < m2)
cout << "\nIncorrect Password..." << endl;
else
cout << "\nWelcome to your Page..." << endl;
return 0;
}
输出:
1).
---------Login----------
Enter the password:
xyz@123
Password you have entered:
xyz@123
Password stored in the system :
xyz@123
Welcome to your Page...
2).
---------Login----------
Enter the password:
abc@123
Password you have entered:
abc@123
Password stored in the system:
xyz@123
Incorrect Password...
在上面的示例中,有两个集合m1和m2。m1包含密码,第二个集合m2存储用户输入的密码。它检查m1是否小于m2。如果m1的密码不小于m2,则登录成功;否则登录失败。