博客
关于我
pair的用法
阅读量:554 次
发布时间:2019-03-09

本文共 1375 字,大约阅读时间需要 4 分钟。

#include <bits/stdc++.h>

using namespace std;

// 比较结构cmp1,按first降序,否则按second升序

struct cmp1{
bool operator()(const pair<int,int>& a, const pair<int,int>& b){
if(a.first != b.first)
return a.first > b.first;
else
return a.second < b.second;
}

// 比较结构cmp2,按second升序,否则按first降序

struct cmp2{
bool operator()(const pair<int,int>& q1, const pair<int,int>& q2){
if(q1.first == q2.first)
return q1.second > q2.second;
else
return q1.first < q2.first;
}

int main(){

// pair的基本用法
pair<int,double> p1(1, 2.2);
pair<int,double> p2;
p2 = p1;
cout << p2.first << " " << p2.second << endl;
p2 = make_pair(1,3);
cout << p2.first << " " << p2.second << endl;

// pair结合其他的用法  pair
p3[10]; for(int i = 0; i < 5; ++i){ p3[i] = make_pair(i, i+1); } sort(p3, p3+5, cmp1); for(int i = 0; i < 5; ++i){ cout << p3[i].first << " " << p3[i].second << endl; } vector
> p4; for(int i = 0; i < 5; ++i){ p4.push_back({1, i+1}); p4.push_back(make_pair(i, i+1)); } sort(p4.begin(), p4.end(), cmp1); int len = p4.size(); for(int i = 0; i < len; ++i){ cout << p4[i].first << " " << p4[i].second << endl; } priority_queue
, vector
>, Greater
> p5; p5.push({2,2}); p5.push({1,2}); p5.push({2,3}); while(!p5.empty()){ cout << p5.top().first << " " << p5.top().second << endl; p5.top(); p5.pop(); }

}

转载地址:http://onwpz.baihongyu.com/

你可能感兴趣的文章
NeHe OpenGL教程 第四十四课:3D光晕
查看>>
Neighbor2Neighbor 开源项目教程
查看>>
neo4j图形数据库Java应用
查看>>
Neo4j图数据库_web页面关闭登录实现免登陆访问_常用的cypher语句_删除_查询_创建关系图谱---Neo4j图数据库工作笔记0013
查看>>
Neo4j图数据库的介绍_图数据库结构_节点_关系_属性_数据---Neo4j图数据库工作笔记0001
查看>>
Neo4j图数据库的数据模型_包括节点_属性_数据_关系---Neo4j图数据库工作笔记0002
查看>>
Neo4j安装部署及使用
查看>>
Neo4j电影关系图Cypher
查看>>
Neo4j的安装与使用
查看>>
Neo4j(1):图数据库Neo4j介绍
查看>>
Neo4j(2):环境搭建
查看>>
Neo4j(3):Neo4j Desktop安装
查看>>
Neo4j(4):Neo4j - CQL使用
查看>>
Neo图数据库与python交互
查看>>
NEO改进协议提案1(NEP-1)
查看>>
Neo私链
查看>>
NervanaGPU 项目使用教程
查看>>
Nerves 项目教程
查看>>
nessus快速安装使用指南(非常详细)零基础入门到精通,收藏这一篇就够了
查看>>
Nessus漏洞扫描教程之配置Nessus
查看>>