栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

c++优先队列小节(常常弄混)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

c++优先队列小节(常常弄混)

C++优先队列(大根堆小根堆)

常见四种形式:

  1. priority_queue p1;
  2. priority_queue p2;
  3. priority_queue,greater > p3;
  4. priority_queue,less > p4;

  1. priority_queue p1;

大根堆:从大到小排序

	priority_queue p1;
	p1.push(1);
	p1.push(2);
	p1.push(5);
	p1.push(3); 
	
	while(!p1.empty()){
		int t = p1.top();
		p1.pop();
		
		cout << t << endl;
	}
	cout << "=================" << endl; 
  1. priority_queue p2;

大根堆:按照first从大到小排序

	priority_queue p2; 
	p2.push(mp(1,2));
	p2.push(mp(2,4));
	p2.push(mp(3,1));
	p2.push(mp(4,2));
	p2.push(mp(5,4));
	p2.push(mp(6,1));
	
	while(!p2.empty()){
		PII t = p2.top();
		p2.pop();
		
		cout << t.fi << " " << t.se << endl;
	}
	cout << "=================" << endl; 
  1. priority_queue,greater > p3;

小根堆:按照first从小到大排序

	priority_queue,greater > p3; 
	p3.push(mp(1,2));
	p3.push(mp(2,4));
	p3.push(mp(3,1));
	p3.push(mp(4,2));
	p3.push(mp(5,4));
	p3.push(mp(6,1));
	
	while(!p3.empty()){
		PII t = p3.top();
		p3.pop();
		
		cout << t.fi << " " << t.se << endl;
	}
	cout << "=================" << endl; 	
  1. priority_queue,less > p4;

大根堆:跟默认一样

	priority_queue,less > p4; 
	p4.push(mp(1,2));
	p4.push(mp(2,4));
	p4.push(mp(3,1));
	p4.push(mp(4,2));
	p4.push(mp(5,4));
	p4.push(mp(6,1));
	
	while(!p4.empty()){
		PII t = p4.top();
		p4.pop();
		
		cout << t.fi << " " << t.se << endl;
	}
	cout << "=================" << endl; 
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/291052.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号