C++ multimap Operator<
C++ Operator < 是multimap的一个非成员重载函数。该函数用于检查第一个multimap是否小于其他multimap。
注意:Operator <按顺序比较multimap的元素,并且比较会在第一个不匹配处停止。
语法
template 
  bool operator<  ( const multimap& lhs,
                    const multimap& rhs );
参数
lhs : 第一个多重映射对象。
rhs : 第二个多重映射对象。
返回值
如果多重映射对象的左侧小于右侧,则返回true;否则返回false。
复杂度
如果lhs和rhs的大小不同,则复杂度为常数。
否则,大小为线性(等式比较)。
迭代器有效性
无更改。
数据竞争
容器lhs和rhs被访问。
异常安全
此函数不抛出异常。
示例1
让我们看一个简单的示例来检查第一个多重映射是否小于:
#include 
#include 
using namespace std;
int main() {
   multimap m1;
   multimap m2;
   m2.emplace('a', 10);
   if (m1 < m2)
      cout << "Multimap m1 is less than m2." << endl;
   m1 = m2;
   if (!(m1 < m2))
      cout << "Multimap m1 is not less than m2." << endl;
   return 0;
}
输出:
Multimap m1 is less than m2.
Multimap m1 is not less than m2.
在上面的示例中,有两个multimap m1和m2。m2包含一个元素,而m1为空。当我们比较这两个multimap时,将显示消息”multimap m1 is less than m2″,然后将m2赋给m1后,这两个multimap都有相同的元素,然后将显示消息”multimap m1 is not less than m2″。
示例2
让我们看一个简单的示例:
#include   
#include   
int main ()  
{  
   using namespace std;  
   multimap  m1, m2, m3;  
   int i;  
   typedef pair  Int_Pair;  
   for (i = 1; i <3; i ++)  
   {  
      m1.insert (Int_Pair (i, i));  
      m2.insert (Int_Pair (i, i * i));  
      m3.insert (Int_Pair (i, i - 1));  
   }  
if (m1 
输出:
The multimap m1 is less than the multimap m2.
The multimap m1 is not less than the multimap m3.
示例3
让我们看一个简单的示例:
#include 
#include 
using namespace std;
int main()
{
  multimap m1, m2;
  m1.insert(make_pair('a',10));
  m1.insert(make_pair('b',20));
  m1.insert(make_pair('c',30));
  m2 = m1;
  cout << (m1 < m2) << endl;
  m2.insert(make_pair('d',40));
  cout << (m1 < m2) << endl;
  return 0;
}
输出:
0
1
在上面的示例中,如果m1小于m2,则返回1,否则返回0。
示例4
#include   
#include   
using namespace std; 
int main ()  
{  
   multimap m2;
   typedef multimap login; 
   m2.insert({2040, "xyz@123"}) ; //stored id and password
   string password;
   int id;
   login m1;
       cout<<"---------Login----------"<> id;              // Get key
       cin>> password;       // Get value
       m1.insert({id, password});   // Put them in multimap
     cout<<"ID and password you have entered: \n";
     for (auto it = m1.begin(); it != m1.end(); it++) {
        cout << (*it).first << "    " << (*it).second << endl;
      }
      cout<<"ID and Password stored in the system :\n";
     for (auto it = m2.begin(); it != m2.end(); it++) {
        cout << (*it).first << "    " << (*it).second << endl;
     }
   if (m1 < m2)  
        cout << "\nIncorrect ID or Password..." << endl; 
   else  
        cout << "\nWelcome to your Page..." << endl;
      return 0;
}
输出结果:
1).
---------Login----------
Enter the ID and password: 
1020     xyz
ID and password you have entered: 
1020     xyz
ID and Password stored in the system:
2040     xyz@123
Incorrect ID or Password...
2).
---------Login----------
Enter the ID and password: 
2040     xyz@123
ID and password you have entered: 
2040     xyz@123
ID and Password stored in the system:
2040     xyz@123
Welcome to your Page...
在上面的示例中,有两个multimap,m1和m2。m1中包含存储的ID和密码,第二个multimap m2存储用户输入的ID和密码。它检查m1是否小于m2。如果m1中的ID和密码不小于m2,则登录成功,否则登录失败。
 极客笔记
极客笔记