Div1 530

  • 感受到被Div1支配的恐惧了.jpg
  • 真·一个题都不会.jpg(虽然T1是我智障
  • 感受到被构造题支配的恐惧了.jpg

A

直接树上贪心就行,是我写错了.jpg

B

这个构造超级神仙有没有.jpg

给定的答案矩阵一定满足,每一行或者每一列只有两种不同的字符交替出现

然后枚举+贪心即可...

C

被老K Diss了.jpg

这题给人的第一印象就是一个非常智障的构造。

然后发现它还有要求...每个节点的度数最大值最小...

然后就不会了.jpg

(开什么玩笑,怎么可能不会!

然后就可以通过枚举这个最大值的方式解决,然后剩下的就直接连在某个点上来满足它的要求...

具体实现看代码吧...有点说不清

总之就是一个$K$叉树+一条链...

#include <bits/stdc++.h>
using namespace std;
#define N 100005
#define ll long long
int fa[N],n,p;ll now,a[N];
int main()
{
scanf("%d%lld",&n,&now);
if(now*2>(ll)n*(n+1))return puts("No"),0;
if(now<n*2-1)return puts("No"),0;
for(p=1;p<=n;p++)
{
long long dep=1,cnt=1,t=1,c=1;
while(cnt<n)c=c*p,dep++,t+=dep*min(c,n-cnt),cnt+=c;
if(t<=now)break;
}
puts("Yes");
long long dep=1,cnt=1,t=1,c=1;a[1]=1;
while(cnt<n)
{
dep++;c=c*p;a[dep]=min(c,n-cnt);
t+=dep*min(c,n-cnt),cnt+=c;
}now-=t;
long long now_d=dep,aft_d=dep+1;
while(now)
{
if(a[now_d]<=1)now_d--;
a[now_d]--;ll tmp=min(aft_d++,now_d+now);
now-=tmp-now_d;a[tmp]++;
}
int lst=1;
for(int i=2;i<aft_d;i++)
{
int nowp=lst-a[i-1]+1,nowk=0;
// printf("%lld\n",a[i]);
for(int j=lst+1;j<=lst+a[i];j++)
{
if(nowk==p)nowp++,nowk=0;
nowk++,fa[j]=nowp;
}lst+=a[i];
}
for(int i=2;i<=n;i++)printf("%d ",fa[i]);puts("");
}
//sdadasdasd

D

这个读题杀啊...

根本读不懂啊.jpg

读懂了就是维护一个动态前缀和来求满足这个式子$sum_{i-1}\times 2\le a_i$的$i$的数量.jpg

那么显然,答案小于$30$

然后就直接树状数组+set即可...

每次找到$\min {a_i}$然后每次翻倍去找+树状数组查前缀和.jpg

就是慢了点.jpg

#include <cstdio>
#include <algorithm>
#include <cmath>
#include <cstring>
#include <cstdlib>
#include <queue>
#include <iostream>
#include <bitset>
#include <set>
using namespace std;
#define N 500005
#define ll long long
int w[N],p[N],n,sp;char str[10];
multiset<int >s;int siz;ll c[N];
void fix(int x,int v){for(;x<=sp;x+=x&-x)c[x]+=v;}
ll find(int x){ll ret=0;for(;x;x-=x&-x)ret+=c[x];return ret;}
void add(int x){siz++;s.insert(p[x]);fix(x,p[x]);}
void del(int x){siz--;s.erase(s.find(p[-x]));fix(-x,-p[-x]);}
int get_ans()
{
if(!siz)return 0;
int ret=1,now=*s.begin();
while(1)
{
if(now>1e9)break;
if(s.upper_bound(now<<1)!=s.end())
{
int t=*s.upper_bound(now<<1);
t=lower_bound(p+1,p+sp+1,t)-p;
if(find(t-1)*2<p[t])ret++;now=p[t]+now;
}else return siz-ret;
}return siz-ret;
}
int main()
{
scanf("%d",&n);
for(int i=1;i<=n;i++)
scanf("%s%d",str,&p[i]),(str[0]=='+'?(w[i]=p[i]):(w[i]=-p[i]));
sort(p+1,p+n+1);sp=unique(p+1,p+n+1)-p-1;
for(int i=1;i<=n;i++)w[i]=(w[i]<0)?-(lower_bound(p+1,p+sp+1,-w[i])-p):lower_bound(p+1,p+sp+1,w[i])-p;
for(int i=1;i<=n;i++)
if(w[i]<0)del(w[i]),printf("%d\n",get_ans());
else add(w[i]),printf("%d\n",get_ans());
}
// dasdasd

Codeforces round 1098的更多相关文章

  1. Codeforces Round #366 (Div. 2) ABC

    Codeforces Round #366 (Div. 2) A I hate that I love that I hate it水题 #I hate that I love that I hate ...

  2. Codeforces Round #354 (Div. 2) ABCD

    Codeforces Round #354 (Div. 2) Problems     # Name     A Nicholas and Permutation standard input/out ...

  3. Codeforces Round #368 (Div. 2)

    直达–>Codeforces Round #368 (Div. 2) A Brain’s Photos 给你一个NxM的矩阵,一个字母代表一种颜色,如果有”C”,”M”,”Y”三种中任意一种就输 ...

  4. cf之路,1,Codeforces Round #345 (Div. 2)

     cf之路,1,Codeforces Round #345 (Div. 2) ps:昨天第一次参加cf比赛,比赛之前为了熟悉下cf比赛题目的难度.所以做了round#345连试试水的深浅.....   ...

  5. Codeforces Round #279 (Div. 2) ABCDE

    Codeforces Round #279 (Div. 2) 做得我都变绿了! Problems     # Name     A Team Olympiad standard input/outpu ...

  6. Codeforces Round #262 (Div. 2) 1003

    Codeforces Round #262 (Div. 2) 1003 C. Present time limit per test 2 seconds memory limit per test 2 ...

  7. Codeforces Round #262 (Div. 2) 1004

    Codeforces Round #262 (Div. 2) 1004 D. Little Victor and Set time limit per test 1 second memory lim ...

  8. Codeforces Round #370 - #379 (Div. 2)

    题意: 思路: Codeforces Round #370(Solved: 4 out of 5) A - Memory and Crow 题意:有一个序列,然后对每一个进行ai = bi - bi  ...

  9. Codeforces Round #371 (Div. 1)

    A: 题目大意: 在一个multiset中要求支持3种操作: 1.增加一个数 2.删去一个数 3.给出一个01序列,问multiset中有多少这样的数,把它的十进制表示中的奇数改成1,偶数改成0后和给 ...

随机推荐

  1. 【读书笔记】iOS-属性

    assign:简单的赋值. retain:赋值之后,会调用新的retain方法和旧值的release方法. copy:表示先将值拷贝一份,然后,将这个拷贝赋值给实例变量,这个修饰词只适用于实现了NSC ...

  2. mysql学习目录

    MySQL数据库 mysql 之库, 表的简易操作 mysql之行(记录)的详细操作 mysql之单表查询 mysql之多表查询 Navicat安装及简单使用 mysql之Navicat工具.pymy ...

  3. SD从零开始64-特异的业务交易(Special Business Transactions)

    紧迫订单Rush Orders 紧迫订单和现金销售是用在从工厂销售流程可能用于当客户需要求即刻从货场获得他们的货物时的销售凭据种类: 在即刻交货的销售凭据种类中,即刻交货符号和交货种类DF是设置的:当 ...

  4. MVC与单元测试实践之健身网站(六)-计划的添加与重置

    健身计划需要使用者自己定制,没有现成的内容可供选择.本篇就是关于健身计划的添加与重置功能的一部分. 一 功能描述 a) 关于计划的定制,决定以周期的方式,比如有人会以一周为周期,然后安排每周的1.3. ...

  5. flow-vue.js移动端效果

    得益于vue.js和element,以及vue-element-extends在线表格编辑.前后端分离的后端用golang+beego框架,服务器采用腾讯云. vue的自适应做的很好,只要将侧栏加一行 ...

  6. Spark ML逻辑回归

    import org.apache.log4j.{Level, Logger} import org.apache.spark.ml.classification.LogisticRegression ...

  7. Java新建Web应用与配置Tomcat流程

    1. 新版本IDEA新建Web应用后没有web.xml文件,需要通过下图方式添加 2. IDEA中的web文件夹相当于eclipse里的WebRoot文件夹,在里面新建WEB-INF文件夹,再创建cl ...

  8. [20180403]访问dba_autotask_task无输出问题.txt

    [20180403]访问dba_autotask_task无输出问题.txt --//链接http://www.itpub.net/thread-1911421-1-1.html的讨论,还没注意原先的 ...

  9. FUSE 文件系统 example部分 源码注释 (libfuse 2.9.9)

    本篇文章主要是针对fuse-2.9.9 Example 部分 给出的源码,结合官方文档,以及网上的资料给出注释,希望能给正在学习的你们一点帮助. Hello.c /* FUSE: Filesystem ...

  10. Linux-lvm逻辑卷管理和提示丢失pv物理卷

    问题描述: 有次在使用lvm扩容的时候,整错了,导致显示如下情况 提示缺少一个pv导致无法继续,pvdisplay的时候查看到unknown 使用pvs查看找到pvname的unknown对应群组ce ...