就按(博主认为的)难度顺序排吧。

Sort It Out

分析

容易发现选出的集合一定是所有逆序对的一个最小覆盖集,那么剩下的就一定是一个LIS。仔细想想还可以发现字典序第\(k\)小的最小覆盖集的补集一定是字典序第\(k\)大的LIS,所以找到这个序列字典序第\(k\)大的LIS就好了。

代码

#include <bits/stdc++.h>

#define rin(i,a,b) for(register int i=(a);i<=(b);++i)
#define irin(i,a,b) for(register int i=(a);i>=(b);--i)
#define trav(i,a) for(register int i=head[a];i;i=e[i].nxt)
typedef long long LL; using std::cin;
using std::cout;
using std::endl; inline LL read(){
LL x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}
return x*f;
} const int MAXN=100005;
const LL inf=1e18+1; int n,a[MAXN],bit[MAXN],f[MAXN];
LL k,retcnt,cnt[MAXN],g[MAXN];
bool vis[MAXN]; struct number{
int pos,val,f;LL g;
inline friend bool operator < (number x,number y){
return x.f==y.f?x.val>y.val:x.f>y.f;
}
}b[MAXN]; #define lowbit(x) ((x)&(-(x))) inline void upd(int x,int kk,LL ll){
for(register int i=x;i<=n;i+=lowbit(i)){
if(kk<bit[i]) continue;
else if(kk==bit[i]){
cnt[i]=std::min(cnt[i]+ll,inf);
}
else{
bit[i]=kk;
cnt[i]=ll;
}
}
} inline int ask(int x){
int ret=0;retcnt=1;
for(register int i=x;i;i-=lowbit(i)){
if(bit[i]<ret) continue;
else if(bit[i]==ret){
retcnt=std::min(retcnt+cnt[i],inf);
}
else{
ret=bit[i];
retcnt=cnt[i];
}
}
return ret;
} #undef lowbit(x) int main(){
n=read(),k=read();int ans=0;
rin(i,1,n) a[i]=read();
irin(i,n,1){
f[i]=ask(n-a[i]+1)+1;
g[i]=retcnt;
upd(n-a[i]+1,f[i],g[i]);
b[i]=(number){i,a[i],f[i],g[i]};
ans=std::max(ans,f[i]);
}
ans=n-ans;
std::sort(b+1,b+n+1);
int now=b[1].f,pos=0,las=0;LL temp=0;
rin(i,1,n){
if(b[i].f!=now||b[i].pos<pos||b[i].val<las) continue;
if(temp+b[i].g>=k){
k-=temp;
temp=0;
--now;
pos=b[i].pos;
las=b[i].val;
vis[b[i].val]=true;
}
else{
temp+=b[i].g;
}
}
printf("%d\n",ans);
rin(i,1,n) if(!vis[i]) printf("%d\n",i);
return 0;
}

The Cow Gathering

分析

有一个简单的结论,就是如果\(a\)必须比\(b\)先离开聚会,那么以\(b\)为根\(a\)的子树内的点的答案就一定是\(0\)。

但是明显这样还会有些问题。显然目前所有答案还有可能为\(1\)的点是连通的,因此一些树边的方向可以被确定。如果我们在已经确定了的关系中找到了环,那么说明整张图的所有点的答案就都是\(0\)。

尽管想到了正解但还是各种疑惑,可能之后会在这里补充一点东西。

代码

#include <bits/stdc++.h>

#define rin(i,a,b) for(register int i=(a);i<=(b);++i)
#define irin(i,a,b) for(register int i=(a);i>=(b);--i)
#define trav(i,a) for(register int i=head[a];i;i=e[i].nxt)
typedef long long LL; using std::cin;
using std::cout;
using std::endl; inline LL read(){
LL x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}
return x*f;
} const int MAXN=100005; int n,m,ecnt,head[MAXN];
int top,sta[MAXN],pos[MAXN],tag[MAXN];
int tot,uu[MAXN<<1],vv[MAXN<<1],deg[MAXN<<1];
bool ok[MAXN];
std::vector<int> vec[MAXN]; struct Edge{
int to,nxt;
}e[MAXN<<1]; inline void add_edge(int bg,int ed){
++ecnt;
e[ecnt].to=ed;
e[ecnt].nxt=head[bg];
head[bg]=ecnt;
} void dfs1(int x,int pre){
sta[++top]=x;
pos[x]=top;
rin(i,0,(int)vec[x].size()-1){
int ver=vec[x][i];
if(!pos[ver]) ++tag[ver];
else{
++tag[1];
--tag[sta[pos[ver]+1]];
}
}
trav(i,x){
int ver=e[i].to;
if(ver==pre) continue;
dfs1(ver,x);
}
--top;
pos[x]=0;
} void dfs2(int x,int pre,int now){
now+=tag[x];
if(!now) ok[x]=true;
trav(i,x){
int ver=e[i].to;
if(ver==pre) continue;
dfs2(ver,x,now);
}
} void dfs3(int x,int pre){
if(pre) ++tot,uu[tot]=pre,vv[tot]=x;
trav(i,x){
int ver=e[i].to;
if(ver==pre) continue;
dfs3(ver,x);
}
} std::queue<int> q; void topo(){
while(!q.empty()) q.pop();
rin(i,1,n) if(!deg[i]) q.push(i);
int cnt=0;
while(!q.empty()){
int x=q.front();q.pop();
++cnt;
trav(i,x){
int ver=e[i].to;
--deg[ver];
if(!deg[ver]) q.push(ver);
}
}
if(cnt<n){
rin(i,1,n) printf("0\n");
exit(0);
}
} int main(){
n=read(),m=read();
rin(i,2,n){
int u=read(),v=read();
add_edge(u,v);
add_edge(v,u);
}
rin(i,1,m){
int u=read(),v=read();
vec[v].push_back(u);
++tot,uu[tot]=v,vv[tot]=u;
}
dfs1(1,0);
dfs2(1,0,0);
int root=0;
rin(i,1,n){
if(ok[i]){
root=i;
break;
}
}
if(!root){
rin(i,1,n) printf("0\n");
return 0;
}
dfs3(root,0);
ecnt=0,memset(head,0,sizeof head);
rin(i,1,tot){
add_edge(uu[i],vv[i]);
++deg[vv[i]];
}
topo();
rin(i,1,n) printf("%d\n",ok[i]?1:0);
return 0;
}

Balance Beam

分析

把期望和凸包结合在了一块,这道题有点神啊。。

贴一个认为讲的不错的博客,本人就不在这里献丑了。

戳我感受大神的洗礼

代码

#include <bits/stdc++.h>

#define rin(i,a,b) for(register int i=(a);i<=(b);++i)
#define irin(i,a,b) for(register int i=(a);i>=(b);--i)
#define trav(i,a) for(register int i=head[a];i;i=e[i].nxt)
typedef long long LL; using std::cin;
using std::cout;
using std::endl; inline int read(){
int x=0,f=1;char ch=getchar();
while(!isdigit(ch)){if(ch=='-')f=-1;ch=getchar();}
while(isdigit(ch)){x=x*10+ch-'0';ch=getchar();}
return x*f;
} const int MAXN=100005; int n,f[MAXN],sta[MAXN],top;
LL ans[MAXN]; bool isleft(int x1,int y1,int x2,int y2,int x3,int y3){
int X1=x2-x1,Y1=y2-y1,X2=x3-x2,Y2=y3-y2;
return 1ll*X1*Y2-1ll*X2*Y1>=0;
} int main(){
n=read();
rin(i,1,n) f[i]=read();
top=0;sta[++top]=0;
rin(i,1,n+1){
while(top>1&&isleft(sta[top-1],f[sta[top-1]],sta[top],f[sta[top]],i,f[i])) --top;
sta[++top]=i;
}
rin(i,2,top){
rin(j,sta[i-1]+1,sta[i])
ans[j]=(1ll*f[sta[i]]*(j-sta[i-1])+1ll*f[sta[i-1]]*(sta[i]-j))*100000/(sta[i]-sta[i-1]);
}
rin(i,1,n) printf("%lld\n",ans[i]);
return 0;
}

USACO2018DEC PLATINUM的更多相关文章

  1. WordPress Platinum SEO插件跨站脚本漏洞

    漏洞名称: WordPress Platinum SEO插件跨站脚本漏洞 CNNVD编号: CNNVD-201309-398 发布时间: 2013-09-24 更新时间: 2013-09-24 危害等 ...

  2. NDK下 将Platinum SDK 编译成so库 (android - upnp)

    Platinum UPnP SDK 是一个跨平台的C++库,利用该库,可以很容易就构建出DLNA/UPnP控制点(DLNA/UPnP Control Point)和DLNA/UPnP设备(DLNA/U ...

  3. 基于Platinum库的DMS实现(android)

    接上篇博文:基于Platinum库的DMR实现(android) 文章讲述了如何使用Platinum库实现DMR 今天同样使用该库,来讲解一下DMS的实现 关于该库如何编译,请参考这篇博文:NDK下 ...

  4. 关于Platinum库的MediaRender具体C++代码实现探讨

    接上篇博文 NDK下 将Platinum SDK 编译成so库 (android - upnp) 讲述了如何利用该代码库编译给android程序调用的so库,其中也提到了,在使用sample-upnp ...

  5. Usaco 2019 Jan Platinum

    Usaco 2019 Jan Platinum 要不是昨天老师给我们考了这套题,我都不知道usaco还有铂金这么一级. 插播一则新闻:杨神坚持认为铂金比黄金简单,原因竟是:铜 汞 银 铂 金(金属活动 ...

  6. Platinum UPnP

    http://www.plutinosoft.com/platinum http://blog.csdn.net/lancees/article/details/9178385 Note that P ...

  7. [转帖]56核Xeon Platinum 9200现身 - 英特尔有史以来最大的CPU封装

    56核Xeon Platinum 9200现身 - 英特尔有史以来最大的CPU封装 https://www.cnbeta.com/articles/tech/835271.htm 当英特尔宣布上周正式 ...

  8. bzoj4409&&bzoj4410&&bzoj4411[Usaco2016 Feb Platinum]题解

    辣鸡wyz最近状态奇差,于是想用usaco题找找手感,万万没想到被虐了一脸TAT 先贴代码,有空再填坑 4409[Usaco2016 Feb]Circular barn #include <io ...

  9. USACO 2015 December Contest, Platinum Problem Max Flow【树链剖分】

    题意比较难理解,就是给你n个点的树,然后给你m个修改操作,每一次修改包括一个点对(x, y),意味着将x到y所有的点权值加一,最后问你整个树上的点权最大是多少. 比较裸的树链剖分了,感谢Haild的讲 ...

随机推荐

  1. 与C++开启新路途

    1.我与C的过去 学习C语言大概是从18年8月开始,一直到19年3月.我完成了对C的基本认识和学习,也顺利通过了二级C计算机的考试.不过当你开始深入于C的世界时,你会发现学习的基础好像略有浅薄.宏的世 ...

  2. MySQL数据库增删改查SQL语句(2018整理集合大全)

    查看数据库 show databases;  使用数据库 use 数据库名; 创建数据库 CREATE DATABASE 数据库名; 删除数据库 DROP DATABASE 数据库名; 创建表 cre ...

  3. 解决 mysql (10038)

    1.授权 mysql>grant all privileges on *.*  to  'root'@'%'  identified by 'youpassword'  with grant o ...

  4. 权限(rwx)对于目录与文件的意义

    1-权限对于目录的意义 首先要明白的是目录主要的内容是记录文件名列表和子目录列表,而不是实际存放数据的地方. r权限:拥有此权限表示可以读取目录结构列表,也就是说可以查看目录下的文件名和子目录名,注意 ...

  5. web-CSS居中大全

    居中是我们使用css来布局时常遇到的情况.使用css来进行居中时,有时一个属性就能搞定,有时则需要一定的技巧才能兼容到所有浏览器,本文就居中的一些常用方法做个简单的介绍. 注:本文所讲方法除了特别说明 ...

  6. 让图表的Y轴 产生几个刻度距离

    动态设置max 查看官网 写入方法 获取到你数据最大值 然后+个100

  7. python、mysql三-2:数据类型

    一 介绍 存储引擎决定了表的类型,而表内存放的数据也要有不同的类型,每种数据类型都有自己的宽度,但宽度是可选的 详细参考: http://www.runoob.com/mysql/mysql-data ...

  8. 关于python导包问题

    讨论采用 * 模糊导入或者 单独导入变量 会在不同文件生成不同的对象 .a └── mypackage ├── a.py ├── b.py ├── c.py   b.py内容如下 import c d ...

  9. javascript模板字符串(标签函数)

    前面介绍了javascript的模板字符串的基本知识,今天深入学习一下标签函数 模板字符串概述 这里先简单说一下模板字符串的概念 1.模板字符串,从名字上可以得出其实返回的是字符串,普通使用其实就想引 ...

  10. 背包 || NOIP 2018 D1 T2 || Luogu P5020 货币系统

    题面:P5020 货币系统 题解: 显然要求的货币系统是当前货币系统的子集时答案会更优,于是考虑从当前货币系统中删数 一个大数如果能被其他小数表示出来,它就可以去掉 把数据排个序去个重,然后直接背包 ...