stl中的很多算法都需要对容器中的元素进行比较,一般进行大小比较的是 <,进行相等比较的是==

重载比较运算符和C++类中的写法相似
写法如下

struct L{
   int a,b;
   //结构体的初始化
   L(int a,int b){
      this->a = a;
      this->b = b;
   }

   //重载 < 运算符
   bool operator <(const L l){
      if(a < l.a) return true;
      else if(a == l.a && b < l.b){
         return true;
      }
      else if(a == l.a && b >= l.b){
         return false;
      }
      else{
         return false;
      }
   }
   
   //重载 == 运算符
   bool operator ==(const L l){
      if(a == l.a && b == l.b) return true;
      return false;
   }
};

int main()
{
   L l1(1,2),l2(1,2);
   printf("%d\n",l1 < l2);
   printf("%d\n",l1 == l2);
}

结果如下:

0
1

值得说明的是 stl中的算法其实是函数的模板,模板只是一种代码形式,这种代码形式具体能完成什么功能,取决于程序员对该模板写法的了解及其想象力。

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐