Painting The Fence(贪心+优先队列)
Painting The Fence(贪心+优先队列)
题目大意:给 m 种数字,一共 n 个,从前往后填,相同的数字最多 k 个在一起,输出构造方案,没有则输出"-1".
解题思路:贪心的思路,优先选择数量多的先填,这样会让最后剩余相同的数字数量最少,所以我们优先选数量最多的两种数字填,最后剩下的(某一种)就填到它前面的位置去,一定是和相同的填在一起,这里就不证明了,自己画下就可以得到。优先队列模拟即可。
AC_Code
/* */
#include <bits/stdc++.h>
#include <iostream>
#include <cstdio>
#include <ctime>
#include <cmath>
#include <utility>
#include <algorithm>
#include <cstring>
#include <queue>
#include <vector>
#include <queue>
#include <map>
#include <set>
#include <stack>
using namespace std;
#define mem0(a) memset(a,0,sizeof(a))
#define mem1(a) memset(a,1,sizeof(a))
typedef long long ll;
typedef unsigned long long ull;
const ll mod = 1e9+;
const int inf=0x3f3f3f3f;
const int INF=0x3f3f3f3f3f3f3f3f;
const double eps=0.000001;
const double pi=acos(-1.0); int n,m,k;
int a[],s[]; struct node///重载,从大到小排序
{
int bianhao,num;
bool operator<(const node &a) const {
return num<a.num;
}
}; priority_queue<node>q; int main()
{
while( ~ scanf("%d%d%d",&n,&m,&k))
{
mem0(a);
mem0(s);
while(!q.empty()) q.pop();
for(int i=; i<=m;i++)
{
node cur;
scanf("%d",&cur.num);
cur.bianhao=i;
q.push(cur);
}
int cnt=;
while( !q.empty() )
{
if( q.size()>= )
{
node n1=q.top(); q.pop();
node n2=q.top(); q.pop();
a[cnt++]=n1.bianhao;
a[cnt++]=n2.bianhao;
n1.num--;
n2.num--;
if( n1.num ) q.push(n1);
if( n2.num ) q.push(n2);
}
else
{
if( a[cnt-]!=q.top().bianhao )
{
node cur=q.top();q.pop();
a[cnt++]=cur.bianhao;
cur.num--;
if(cur.num) q.push(cur);
}
break;
}
}
for(int i=; i<cnt&&!q.empty(); i++)
{
if( a[i]==q.top().bianhao )
{
s[i]+=min(q.top().num,k-);
node cur=q.top();q.pop();
cur.num-=min(cur.num,k-);
if( cur.num ) q.push(cur);
else break;
}
}
if( !q.empty()) printf("-1\n");
else
{
for(int i=;i<cnt;i++)
{
for(int j=;j<=s[i]; j++)
{
printf("%d ",a[i]);
}
}
printf("\n");
}
}
return ;
}
Painting The Fence(贪心+优先队列)的更多相关文章
- hihoCoder 1309:任务分配 贪心 优先队列
#1309 : 任务分配 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 描述 给定 N 项任务的起至时间( S1, E1 ), ( S2, E2 ), ..., ( SN, ...
- UVA 11134 - Fabled Rooks(贪心+优先队列)
We would like to place n rooks, 1 ≤ n ≤ 5000, on a n×n board subject to the following restrict ...
- poj 3253 Fence Repair 优先队列
poj 3253 Fence Repair 优先队列 Description Farmer John wants to repair a small length of the fence aroun ...
- C. Playlist Educational Codeforces Round 62 (Rated for Div. 2) 贪心+优先队列
C. Playlist time limit per test 2 seconds memory limit per test 256 megabytes input standard input o ...
- [luogu P2205] [USACO13JAN]画栅栏Painting the Fence
[luogu P2205] [USACO13JAN]画栅栏Painting the Fence 题目描述 Farmer John has devised a brilliant method to p ...
- 洛谷 画栅栏Painting the Fence 解题报告
P2205 画栅栏Painting the Fence 题目描述 \(Farmer\) \(John\) 想出了一个给牛棚旁的长围墙涂色的好方法.(为了简单起见,我们把围墙看做一维的数轴,每一个单位长 ...
- HDU 6438 网络赛 Buy and Resell(贪心 + 优先队列)题解
思路:维护一个递增队列,如果当天的w比队首大,那么我们给收益增加 w - q.top(),这里的意思可以理解为w对总收益的贡献而不是真正获利的具体数额,这样我们就能求出最大收益.注意一下,如果w对收益 ...
- 贪心+优先队列 HDOJ 5360 Hiking
题目传送门 /* 题意:求邀请顺序使得去爬山的人最多,每个人有去的条件 贪心+优先队列:首先按照l和r从小到大排序,每一次将当前人数相同的被邀请者入队,那么只要能当前人数比最多人数条件小,该人能 被邀 ...
- [POJ1456]Supermarket(贪心 + 优先队列 || 并查集)
传送门 1.贪心 + 优先队列 按照时间排序从前往后 很简单不多说 ——代码 #include <queue> #include <cstdio> #include <i ...
随机推荐
- 将 C++/WinRT 中的线程切换体验带到 C# 中来(WPF 版本)
原文:将 C++/WinRT 中的线程切换体验带到 C# 中来(WPF 版本) 如果你要在 WPF 程序中使用线程池完成一个特殊的任务,那么使用 .NET 的 API Task.Run 并传入一个 L ...
- 【openshift】OC命令部署Openshift
OC命令部署Openshift # install openshift wget -c https://github.com/openshift/origin/releases/download/v3 ...
- 【转】【Salesforce】salesforce 零基础学习(十七)Trigger用法
看本篇之前可以相应阅读以下Trigger相关文章: 1.https://developer.salesforce.com/page/Trigger_Frameworks_and_Apex_Trigge ...
- Android选项卡TabHost功能和用法
1.布局文件 <TabHost xmlns:android="http://schemas.android.com/apk/res/android" xmlns:tools= ...
- Spring 实例化Bean的3种方式
要使用Spring中的Bean,需要先创建这个Bean的实例. 实例化Bean有3种方式: 构造器方式 静态工厂方式 实例工厂方式 构造器方式 构造器方式是最常用的.在Bean中写构造函数,然后在配置 ...
- Alpha_4
一. 站立式会议照片 二. 工作进展 (1) 昨天已完成的工作 a. 我的·主界面设计 b. 番茄钟的页面及音乐选择弹窗页面设计 c. 实现自定义习惯和设置新习惯的功能页面,并可预览 d.已实现番茄钟 ...
- 日志 logback-spring.xml配置
文章转载自: https://blog.csdn.net/xu_san_duo/article/details/80364600 logback-spring.xml配置文件 1. 自己改下value ...
- day 14作业
作业 现有文件info.txt, 其内容如下: alpha male 18 1000 bravo male 28 2000 charlie female 38 3000 delta female 48 ...
- MYSQL使用source命令,导入SQL文件
命令 source D:/student.sql
- MySQL-CentOS7上安装Mysql5.7
#安装 wget http://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm .noarch.rpm yum instal ...