Codeforces Round #398 (Div. 2)
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)的更多相关文章
- Codeforces Round #398 (Div. 2) A. Snacktower 模拟
A. Snacktower 题目连接: http://codeforces.com/contest/767/problem/A Description According to an old lege ...
- Codeforces Round #398 (Div. 2) C. Garland —— DFS
题目链接:http://codeforces.com/contest/767/problem/C 题解:类似于提着一串葡萄,用剪刀剪两条藤,葡萄分成了三串.问怎样剪才能使三串葡萄的质量相等. 首先要做 ...
- Codeforces Round #398 (div.2)简要题解
这场cf时间特别好,周六下午,于是就打了打(谁叫我永远1800上不去div1) 比以前div2的题目更均衡了,没有太简单和太难的...好像B题难度高了很多,然后卡了很多人. 然后我最后做了四题,E题感 ...
- 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 ...
- 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 ...
- 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 ...
- 【DFS】Codeforces Round #398 (Div. 2) C. Garland
设sum是所有灯泡的亮度之和 有两种情况: 一种是存在结点U和V,U是V的祖先,并且U的子树权值和为sum/3*2,且U不是根,且V的子树权值和为sum/3. 另一种是存在结点U和V,他们之间没有祖先 ...
- 【枚举】【贪心】 Codeforces Round #398 (Div. 2) B. The Queue
卡题意……妈的智障 一个人的服务时间完整包含在整个工作时间以内. 显然,如果有空档的时间,并且能再下班之前完结,那么直接输出即可,显然取最左侧的空档最优. 如果没有的话,就要考虑“挤掉”某个人,就是在 ...
- 【暴力】Codeforces Round #398 (Div. 2) A. Snacktower
题意不复述. 用个bool数组记录一下,如果某一天,当前剩下的最大的出现了的话,就输出一段. #include<cstdio> using namespace std; int n; bo ...
随机推荐
- Spring学习日志之Glance
Spring的本质 Spring最根本的意图只有一个:简化Java开发 Spring的核心主要有两个: 依赖注入 AOP Spring容器 Spring容器负责对对象进行创建,装配,配置并管理它们的整 ...
- JAVA开发中遇到的异常总结
最常见的五种异常:必会,面试题: 算术异常类:ArithmeticExecption 空指针异常类:NullPointerException 类型强制转换异常:ClassCastException 数 ...
- [国嵌攻略][061][2440LCD驱动设计]
LCD初始化 1.引脚初始化 2.时序初始化 VBPD(vertical back porch):表示在一帧图像开始时,垂直同步信号以后的无效的行数 VFBD(vertical front porch ...
- Tomcat源码调试环境搭建
我们一般都是为了解决某个问题,才去看源码的.Java体系就是这点好处,源码唾手可得.遇到问题,最后的解决方法总是可以从源码中找到. 参考了网上的文章,过程整理如下: 1. 下载和导入 官网下载编译好的 ...
- [C#]使用控制台获取天气预报
本例子主要是使用由中央气象局网站(http://www.nmc.gov.cn)提供的JSON API,其实现思路如下: 1.访问获取省份(包含直辖市.自治区等,以下简称省份)的网址(http://ww ...
- PHP中file_exists()函数不能检测包含中文的文件名的解决办法
版权声明:本文为博主原创文章,未经博主允许不得转载. PHP中一般使用file_exists()判断某个文件或者文件夹是否存在,如果文件或文件夹存在则返回true,不存在则返回fal ...
- python通过scapy模块进行arp断网攻击
前言: 想实现像arpsoof一样的工具 arp断网攻击原理: 通过伪造IP地址与MAC地址实现ARP欺骗,在网络发送大量ARP通信量.攻击者 只要持续不断发送arp包就能造成中间人攻击或者断网攻击. ...
- 【绘图技巧】ps快捷键的用法
Ctrl+N:新建画布 Ctrl+O:打开对话框 F: 在三种画布中切换 Z:缩放工具(临时) Ctrl+0:满画面显示 空格:切换到手(临时) Ctrl+":网 ...
- 优化表单数据的JS校验
在平常的web开发中,我经常需要在客户端对表单的数据进行验证.比如,我们验证表单输入的内容不为空: ? <form action="" method="post&q ...
- lodash源码分析之缓存使用方式的进一步封装
在世界上所有的民族之中,支配着他们的喜怒选择的并不是天性,而是他们的观点. --卢梭<社会与契约论> 本文为读 lodash 源码的第九篇,后续文章会更新到这个仓库中,欢迎 star:po ...