题目链接

BZOJ3523

题解

简单的贪心题

优先与上一个不一样且数量最多的,如果有多个相同,则优先选择非结尾颜色

比较显然,但不知怎么证

#include<algorithm>
#include<iostream>
#include<cstring>
#include<cstdio>
#include<queue>
#include<cmath>
#include<map>
#define Redge(u) for (int k = h[u],to; k; k = ed[k].nxt)
#define REP(i,n) for (int i = 1; i <= (n); i++)
#define mp(a,b) (cp){a,b}
#define cls(s) memset(s,0,sizeof(s))
#define LL long long int
using namespace std;
const int maxn = 1000005,maxm = 100005,INF = 1000000000;
inline int read(){
int out = 0,flag = 1; char c = getchar();
while (c < 48 || c > 57){if (c == '-') flag = -1; c = getchar();}
while (c >= 48 && c <= 57){out = (out << 3) + (out << 1) + c - 48; c = getchar();}
return out * flag;
}
int ans[maxn],n,s,t,m;
struct cp{
int cnt,id;
};
inline bool operator <(const cp& a,const cp& b){
return a.cnt == b.cnt ? a.id != t : a.cnt < b.cnt;
}
priority_queue<cp> q;
int main(){
n = read(),s = read(),t = read();
if (n == 1 && (s != t)){puts("0"); return 0;}
int tmp;
REP(i,n){
tmp = read(); m += tmp;
if (i == s) tmp--;
if (i == t) tmp--;
if (tmp == -1){puts("0"); return 0;}
if (tmp) q.push(mp(tmp,i));
}
cp u,v;
ans[1] = s; ans[m] = t;
for (int i = 2; i < m; i++){
u = q.top(); q.pop();
if (u.id == ans[i - 1]){
if (q.empty()){puts("0"); return 0;}
v = q.top(); q.pop();
ans[i] = v.id; v.cnt--;
q.push(u);
if (v.cnt) q.push(v);
}
else {
ans[i] = u.id; u.cnt--;
if (u.cnt) q.push(u);
}
}
if (ans[m - 1] == t){puts("0"); return 0;}
for (int i = 1; i <= m; i++)
printf("%d ",ans[i]);
return 0;
}

最新文章

  1. .NET应用程序调试—原理、工具、方法
  2. async和await
  3. The Earth Mover&#39;s Distance
  4. 团队项目--站立会议DAY5
  5. Ubuntu上如何安装Java,Eclipse,Pydev,Python(自带,不用装),BeautifulSoup
  6. [daily][network] NAT原理(转)
  7. Ubuntu 下无法Tab键自动补全功能解决办法
  8. Project Euler 94:Almost equilateral triangles 几乎等边的三角形
  9. git源码中的Makefile
  10. Android用户界面UI组件--AdapterView及其子类(四) GridView
  11. RT:How HTTP use TCP connection
  12. BZOJ 1143 [CTSC2008]祭祀river(二分图匹配)
  13. 华为-on练习--身高找到最好的二人
  14. iOS 通知的使用
  15. lesson - 13 Linux系统日常管理2
  16. Making A Circle Out Of Squares
  17. [winograd]winograd算法在卷积中的应用
  18. Java入门(七):方法
  19. vue的cli中引入css文件
  20. Postgres 的 deferrable

热门文章

  1. dubbo入门(一)
  2. 「LeetCode」0002-Longest Substring Without Repeating Characters(C++)
  3. Linux系统中ElasticSearch搜索引擎安装配置Head插件
  4. hdu2112HDU Today(floyd+map数组对字符串的应用)
  5. Django模型与创建管理员用户
  6. python基础之全局局部变量及函数参数
  7. Unity Lighting - Choosing a Rendering Path 选择渲染路径(三)
  8. C 计算时间差
  9. 【WXS】变量定义保留标识符
  10. CodeForces - 776C(前缀和+思维)