C++ std operator< 函数

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,则登录成功;否则登录失败。

Camera课程

Python教程

Java教程

Web教程

数据库教程

图形图像教程

办公软件教程

Linux教程

计算机教程

大数据教程

开发工具教程