zoukankan      html  css  js  c++  java
  • 运算符重载 与 sort()

    运算符重载与sort()

    二话不说上代码:

     1 #include <iostream>
     2 #include <algorithm>
     3 using namespace std;
     4 struct type_1
     5 {
     6     int a,b;
     7     type_1(int x=0,int y=0):a(x),b(y){}
     8 };
     9 bool compare(type_1 a,type_1 b)
    10 {
    11     return a.a<b.a;
    12 }
    13 bool operator < (const type_1 &a,const type_1 &b)
    14 {
    15     return a.a<b.a;
    16 }
    17 ostream& operator<<(ostream &cout,const type_1 &a)
    18 {
    19     cout<<"("<<a.a<<","<<a.b<<")";
    20 }
    21 int main()
    22 {
    23     type_1 vec[10]={type_1(3,4),type_1(2,4),type_1(1,4),type_1(9,4),type_1(31,4),type_1(25,4),type_1(2,4),type_1(9,4),type_1(2,4),type_1(1,4)};
    24     sort(vec,vec+10);//通过定义小于<
    25     for(int i=0;i<10;i++)
    26         cout<<vec[i]<<" ";
    27         cout<<endl;
    28 
    29     return 0;
    30 }

    此函数 展示了:

    ①"<"逻辑符的重载

    ②"cout"输出的重载

    ③“sort()”的两种排序规则的定义:一种是通过定义逻辑函数"compare",另一种是通过重载逻辑运算符"<"

    ④更明白了 compare 是定义一种小于

    2017-03-11 22:53:34

  • 相关阅读:
    树链剖分
    NOI2015 软件包管理器(树链剖分+线段树)
    9.11NOIP模拟题
    9.10NOIP模拟题
    bzoj1121[POI2008]激光发射器SZK(结论)
    9.9 NOIP模拟题
    树形dp
    P1272 重建道路(树形dp)
    Codeforces Round #419 (Div. 2)
    9.2NOIP模拟题
  • 原文地址:https://www.cnblogs.com/Twobox/p/6536556.html
Copyright © 2011-2022 走看看