P3378 堆(模板)
P3378 【模板】堆
题目描述
给定一个数列,初始为空,请支持下面三种操作:
给定一个整数 x,请将 x 加入到数列中。
输出数列中最小的数。
删除数列中最小的数(如果有多个数最小,只删除 1 个)。
输入格式
第一行是一个整数,表示操作的次数 n。
接下来 n 行,每行表示一次操作。每行首先有一个整数 op 表示操作类型。
若 op = 1,则后面有一个整数x,表示要将 x 加入数列。
若op=2,则表示要求输出数列中的最小数。
若 op = 3,则表示删除数列中的最小数。如果有多个数最小,只删除1 个。
输出格式
- 对于每个操作 2,输出一行一个整数表示答案。
输入输出样例
输入
5
1 2
1 5
2
3
2
输出
2
5
说明/提示
数据规模与约定
- 对于 30% 的数据,保证 n≤15。
- 对于 70% 的数据,保证 n≤10^4-。
- 对于 100% 的数据,保证 1≤n≤10^6,1≤x<2^31,op∈{1,2,3}。
思路1
这道题是堆的模板题目,我们可以用堆来做这题
但是直接用堆来做的话会超时,建议用思路2来做
代码
#include<bits/stdc++.h>
#pragma GCC optimize(100)
using namespace std;
int dui[100001];
int n=0;
void downadjust(int low,int high){
int i=low,j=i*2;
while(j<=high){
if(j+1<=high&&dui[j+1]>dui[j]){
j=j+1;
}
if(dui[j]>dui[i]){
swap(dui[j],dui[i]);
i=j;
j=i*2;
}else{
break;
}
}
}
void build(){
for(int i=n/2;i>=1;i--){
downadjust(i,n);
}
}
void deletetop(){
dui[1]=dui[n--];
downadjust(1,n);
}
void duisort(){
build();
for(int i=n;i>=1;i--){
swap(dui[i],dui[1]);
downadjust(1,i-1);
}
}
void upadjust(int low,int high){
int i=high,j=i/2;
while(j>=low){
if(dui[j]<dui[i]){
swap(dui[j],dui[i]);
i=j;
j=i/2;
}else{
break;
}
}
}
void deleteany(int x){
dui[x]=dui[--n];
upadjust(1,x);
downadjust(x,n);
}
void insert(int i){
dui[++n]=i;
upadjust(1,n);
}
int main(){
ios::sync_with_stdio(false);
int t;
cin>>t;
int a,b;
int vis=0;
for(int i=1;i<=t;i++){
cin>>a;
vis=0;
if(a==1){
cin>>b;
insert(b);
}
else if(a==2){
duisort();
vis=1;
cout<<dui[1]<<endl;
}
else{
duisort();
deletetop();
}
}
return 0;
}
思路2
这道题我们还可以直接用优先队列,来模拟栈(值小的优先级大,所以要重定义priority_queue)
priority_queue<int,vector<int>,greater<int> >q;
代码
#include<bits/stdc++.h>
using namespace std;
int main(){
priority_queue<int,vector<int>,greater<int> >q;
int n;
cin>>n;
int a,b;
for(int i=1;i<=n;i++){
cin>>a;
if(a==1){
cin>>b;
q.push(b);
}
else if(a==2){
cout<<q.top()<<endl;
}
else{
q.pop();
}
}
return 0;
}
P3378 堆(模板)的更多相关文章
- P3378 堆の模板
如果不是可并堆/带修堆/卡常题,一般都用优先队列实现. 很多O(nlogn)过不了的题都可以用蚯蚓的套路来实现!!! 优先队列带修用延迟删除法. 堆,可以简单的用优先队列来实现,也可以自己手打. #i ...
- 洛谷P3378 【模板】堆
P3378 [模板]堆 160通过 275提交 题目提供者HansBug 标签 难度普及- 提交 讨论 题解 最新讨论 经实际测试 堆的数组开3000- 题目有个问题 为什么这个按课本堆标准打的- ...
- P3378 【模板】堆 (内含左偏树实现)
P3378 [模板]堆 题解 其实就是一个小根堆啦,STL就可以解决,但是拥有闲情雅致的我学习了Jelly_Goat的左偏树,增加了代码长度,妙啊 Solution 1 STL STL 里面prior ...
- 可并堆模板题-mergeable heap
Description 有n个点,第i个点标号为i,有两种操作:0 x y 表示把x所在堆和y所在堆合并.1 x 表示询问x所在堆的最小权. Input 第一行两个整数n,m,表示有n个点m个操作. ...
- 【luogu P3378 堆】 模板
题目链接:https://www.luogu.org/problemnew/show/P3378 是堆的模板...我懒,STL da fa is good #include <iostream& ...
- Luogu P3378 【模板】堆
((^ 0.0 ^) )~ 堆是一个完全二叉树,对于小根堆,所有父节点<=子节点,下标就和线段树是一样的 在STL里就是优先队列 只有堆顶元素可以操作(询问或弹出). 加入新元素时x,he ...
- 堆模板(pascal)洛谷P3378
题目描述 如题,初始小根堆为空,我们需要支持以下3种操作: 操作1: 1 x 表示将x插入到堆中 操作2: 2 输出该小根堆内的最小数 操作3: 3 删除该小根堆内的最小数 输入输出格式 输入格式: ...
- 洛谷 P3378 【模板】堆
如题,初始小根堆为空,我们需要支持以下3种操作: 操作1: 1 x 表示将x插入到堆中 操作2: 2 输出该小根堆内的最小数 操作3: 3 删除该小根堆内的最小数 输入输出格式 输入格式: 第一行包含 ...
- P3378 堆【模板】 洛谷
https://www.luogu.org/problem/show?pid=3378 题目描述 如题,初始小根堆为空,我们需要支持以下3种操作: 操作1: 1 x 表示将x插入到堆中 操作2: 2 ...
随机推荐
- Istio安全-授权(实操三)
Istio安全-授权 目录 Istio安全-授权 授权HTTP流量 为使用HTTP流量的负载配置访问控制 卸载 授权TCP流量 部署 配置TCP负载的访问控制 卸载 使用JWT进行授权 部署 使用有效 ...
- 喵的Unity游戏开发之路 - 游泳
原文: https://mp.weixin.qq.com/s/-ERFNB1GRZ6UAkHOhP9UQw 很多童鞋没有系统的Unity3D游戏开发基础,也不知道从何开始学.为此我们精选了一套国外优秀 ...
- Photogrammetry and Game
https://skulltheatre.wordpress.com/2013/02/11/photogrammetry-in-video-games-frequently-asked-questio ...
- Java中的IO操作和缓冲区
目录 Java中的IO操作和缓冲区 一.简述 二.IO流的介绍 什么是流 输入输出流的作用范围 三.Java中的字节流和字符流 字节流 字符流 二者的联系 1.InputStreamReader 2. ...
- 文本三剑客之grep的用法
第1章 正则表达式 1.1 正则表达式的介绍 正则是用来过滤文件内容 为处理大量文本|字符串而定义的一套规则和方法. ...
- vue中实现后台管理路由标签页
<template> <section> <div class="navTabList el-tabs__nav-scroll" id="t ...
- C002:计算球体体积(半径固化)
程序: #include "stdafx.h" int _tmain(int argc, _TCHAR* argv[]) { float sphereRadius=10.0f; f ...
- 在微信公众号"码海"里学了一招:在update语句里使用case when 以避免多次更新导致的数据异常.
需求:将emp表中工资大于一万的降到9成,工资少于一万的乘以1.2. 难点:如果分成两句update执行,在10000附近的值可能会执行两次. 钥匙:在update语句里采用case when,使更新 ...
- MyBatis源码流程分析
mybatis核心流程三大阶段 Mybatis的初始化 建造者模式 建造者模式(Builder Pattern)使用多个简单的对象一步一步构建成一个复杂的对象.这种类型的设计模式属于创建型模式,它提 ...
- CentOS7下mysql忘记root密码的处理方法
1. vi /etc/my.cnf,在[mysqld]中添加 skip-grant-tables 例如: [mysqld] skip-grant-tables datadir=/var/lib/my ...