Codeforces Round #398 (Div. 2)

A.Snacktower

模拟

我和官方题解的命名神相似...$has$

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
typedef long long ll;
const int N=1e5+;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
}
int n,has[N];
int main(){
//freopen("in","r",stdin);
n=read();
int now=n;
for(int i=;i<=n;i++){
has[read()]=;
while(has[now]) printf("%d ",now),now--;
puts("");
}
}

B.The Queue

比赛时花了1h然后弃疗

感觉好恶心...


C.Garland

题意:一颗二叉树切断两条边分成三部分使得三部分权值和相等

感觉比B简单(好写)多了,可以发现每部分权值和就是总权值的$\frac{1}{3}$

然后我用了两个树形DP,$d[i]$表示$i$子树权值和,$f[i]$表示$i$子树里有几个权值和等于$\frac{1}{3}$的

分类讨论选的两棵子树是否互相包含,比赛时各种$debug$,最后$5min$通过了...感动

#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <cmath>
using namespace std;
typedef long long ll;
const int N=1e6+;
inline int read(){
char c=getchar();int x=,f=;
while(c<''||c>''){if(c=='-')f=-; c=getchar();}
while(c>=''&&c<=''){x=x*+c-''; c=getchar();}
return x*f;
}
int n,d[N],fa,w[N],root;
struct edge{
int v,ne;
}e[N<<];
int h[N],cnt=;
inline void ins(int u,int v){
cnt++;
e[cnt].v=v;e[cnt].ne=h[u];h[u]=cnt;
}
void dp(int u){
d[u]=w[u];
for(int i=h[u];i;i=e[i].ne)
dp(e[i].v),d[u]+=d[e[i].v];
}
int f[N],val;
void dp2(int u){
for(int i=h[u];i;i=e[i].ne){
int v=e[i].v;
dp2(v);
if(f[v]==) f[u]+=d[v]==val;
else f[u]+=f[v];
}
}
int a[N],p;
int main(){
//freopen("in","r",stdin);
n=read();
for(int i=;i<=n;i++){
fa=read();w[i]=read();
if(fa==) root=i;
else ins(fa,i);
}
dp(root);
if(d[root]%!=) puts("-1");
else{
val=d[root]/;
dp2(root);
//for(int i=1;i<=n;i++) printf("%d %d %d\n",i,d[i],f[i]);
if(f[root]==) puts("-1");
else if(f[root]>=){
for(int i=;i<=n;i++) if(i!=root&&d[i]==val&&f[i]==) a[++p]=i;
printf("%d %d",a[],a[]);
}else{
int flag=,a,b;
for(int i=;i<=n;i++) if(i!=root&&d[root]-d[i]==val&&f[i]==){
flag=;a=i;break;
}
for(int i=;i<=n;i++) if(i!=root&&d[i]==val&&f[i]==) {b=i;break;}
if(flag) printf("%d %d",a,b);
else puts("-1");
}
}
}

D.Cartons of milk

赛后补题.....

一开始贪心乱搞失败,然后发现直接二分答案就好了.....然而是$O(n log^{2}n)$.....

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
typedef long long ll;
const int N=2e6+;
inline int read(){
char c=getchar();int x=;
while(c<''||c>''){c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x;
}
int n,m,k,a[N];
struct data{
int id,b;
bool operator <(const data &r) const{
return b>r.b;
}
}b[N];
int p,c[N];
bool check(int x){//printf("check %x\n",x);
ll now=;
p=;
for(int i=;i<=n;i++) c[++p]=a[i];
for(int i=;i<=x;i++) c[++p]=b[i].b;
sort(c+,c++p);
//for(int i=1;i<=p;i++) printf("%d ",c[i]);puts("");
for(int i=;i<=p;i++){
now++;//printf("now %d %d %d\n",i,c[i],now);
if(now>(ll)k*c[i]) return false;
}
return true;
}
int main(){
//freopen("in","r",stdin);
n=read();m=read();k=read();
for(int i=;i<=n;i++) a[i]=read()+;
for(int i=;i<=m;i++) b[i].b=read()+,b[i].id=i;
sort(a+,a++n);
sort(b+,b++m);
int l=,r=m,ans=-;
while(l<=r){
int mid=(l+r)>>;
if(check(mid)) ans=mid,l=mid+;
else r=mid-;
}
printf("%d\n",ans);
if(ans!=-){
memset(c,,sizeof(c));
for(int i=;i<=ans;i++) c[b[i].id]=;
for(int i=;i<=m;i++) if(c[i]) printf("%d ",i);
}
}

看了一个别人的代码发现贪心也能做并且很快

$f[i]$记录时间i选了几个,贪心选择放在最晚到期,然后从后往前$>k$的给前面就行了,$O(n)$,时间只有二分答案的$\frac{1}{3}$

#include <iostream>
#include <cstdio>
#include <cstring>
#include <algorithm>
#include <cmath>
using namespace std;
typedef long long ll;
const int N=2e6+,M=1e7+;
inline int read(){
char c=getchar();int x=;
while(c<''||c>''){c=getchar();}
while(c>=''&&c<=''){x=x*+c-'';c=getchar();}
return x;
}
int n,m,k,a[N];
struct data{
int id,b;
bool operator <(const data &r) const{
return b>r.b;
}
}b[N];
int f[M],mx;
bool vis[N];
int main(){
//freopen("in","r",stdin);
n=read();m=read();k=read();
for(int i=;i<=n;i++) a[i]=read()+,f[a[i]]++,mx=max(mx,a[i]);
for(int i=;i<=m;i++) b[i].b=read()+,b[i].id=i,mx=max(mx,b[i].b);
sort(a+,a++n);
for(int i=mx;i>=;i--) if(f[i]>k) f[i-]+=f[i]-k,f[i]=k;
if(f[]) puts("-1");
else{
sort(b+,b++m);
for(int i=;i<=m;i++) f[b[i].b]++;
for(int i=mx;i>=;i--) if(f[i]>k) f[i-]+=f[i]-k,f[i]=k;
int p=m-f[];
printf("%d\n",p);
for(int i=;i<=p;i++) vis[b[i].id]=;
for(int i=;i<=m;i++) if(vis[i]) printf("%d ",i);
}
}

Codeforces Round #398 (Div. 2)的更多相关文章

  1. Codeforces Round #398 (Div. 2) A. Snacktower 模拟

    A. Snacktower 题目连接: http://codeforces.com/contest/767/problem/A Description According to an old lege ...

  2. Codeforces Round #398 (Div. 2) C. Garland —— DFS

    题目链接:http://codeforces.com/contest/767/problem/C 题解:类似于提着一串葡萄,用剪刀剪两条藤,葡萄分成了三串.问怎样剪才能使三串葡萄的质量相等. 首先要做 ...

  3. Codeforces Round #398 (div.2)简要题解

    这场cf时间特别好,周六下午,于是就打了打(谁叫我永远1800上不去div1) 比以前div2的题目更均衡了,没有太简单和太难的...好像B题难度高了很多,然后卡了很多人. 然后我最后做了四题,E题感 ...

  4. Codeforces Round #398 (Div. 2) A,B,C,D

    A. Snacktower time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  5. Codeforces Round #398 (Div. 2) A B C D 模拟 细节 dfs 贪心

    A. Snacktower time limit per test 2 seconds memory limit per test 256 megabytes input standard input ...

  6. Codeforces Round #398 (Div. 2) B,C

    B. The Queue time limit per test 1 second memory limit per test 256 megabytes input standard input o ...

  7. 【DFS】Codeforces Round #398 (Div. 2) C. Garland

    设sum是所有灯泡的亮度之和 有两种情况: 一种是存在结点U和V,U是V的祖先,并且U的子树权值和为sum/3*2,且U不是根,且V的子树权值和为sum/3. 另一种是存在结点U和V,他们之间没有祖先 ...

  8. 【枚举】【贪心】 Codeforces Round #398 (Div. 2) B. The Queue

    卡题意……妈的智障 一个人的服务时间完整包含在整个工作时间以内. 显然,如果有空档的时间,并且能再下班之前完结,那么直接输出即可,显然取最左侧的空档最优. 如果没有的话,就要考虑“挤掉”某个人,就是在 ...

  9. 【暴力】Codeforces Round #398 (Div. 2) A. Snacktower

    题意不复述. 用个bool数组记录一下,如果某一天,当前剩下的最大的出现了的话,就输出一段. #include<cstdio> using namespace std; int n; bo ...

随机推荐

  1. Flask连接数据库打怪升级之旅

    一.前言 在初学 Flask 的时候,在数据库连接这部分也跟每个初学者一样.但是随着工作中项目接手的多了,代码写的多了,历练的多了也就有了自己的经验和技巧.在对这块儿代码不断的进行升级改造后,整理了在 ...

  2. Spark算子--filter

    filter--Transformation类算子 代码示例 result    

  3. 【转载备忘】PowerDesigner16.5基本使用

    这两天都在设计数据库,使用了powerdesigner进行设计的,然后摸索了好久,本来打算写一篇文章来记述一下的,写了一半,突然发现网上早就有比我写的好的文章了,所有删了之前写的,直接贴出来那个文章的 ...

  4. windows server 2008使用nginx转发API异常解决办法

    公司比较传统,一直使用的JSP做项目,没有遇到过跨域问题. 最近因为公司接到一个微信spa项目,因为考虑到项目需要调用老接口,斗胆选择nginx(1.12.1)做接口转发服务, 开发环境使用的win1 ...

  5. 什么是MVC ?

    记得第一次面试phper(php是对我来说可以快速上手的另一web开发语言),人家问我MVC,我只知道m就是model,v就是view,c就是Controller,具体把其它的认识我是一无所知,结果我 ...

  6. 最强PostMan使用教程(1)

    最近需要测试产品中的REST API,无意中发现了PostMan这个chrome插件,把玩了一下,发现postman秉承了一贯以来google工具强大,易用的特质.独乐乐不如众乐乐,特此共享出来给大伙 ...

  7. SendCloud邮件中为什么会显示代发

    显示代发是发信的sender和发信人地址(from)不一致导致的. sender是SendCloud系统根据用户自设的发信域名生成的,目前是"随机地址@自有域名"做sender,所 ...

  8. Kafka 使用Java实现数据的生产和消费demo

    前言 在上一篇中讲述如何搭建kafka集群,本篇则讲述如何简单的使用 kafka .不过在使用kafka的时候,还是应该简单的了解下kafka. Kafka的介绍 Kafka是一种高吞吐量的分布式发布 ...

  9. 一简单的RPC实例(Java)

    来至于阿里liangf:如有冒犯,请原谅 RPCFrameWork: package com.sunchao.demo; import java.io.IOException; import java ...

  10. 直接请求转发(Forward)和间接请求转发(Redirect)两种区别?

    用户向服务器发送了一次HTTP请求,该请求肯能会经过多个信息资源处理以后才返回给用户,各个信息资源使用请求转发机制相互转发请求,但是用户是感觉不到请求转发的.根据转发方式的不同,可以区分为直接请求转发 ...