atcoder tokiomarine2020 部分口胡题解

2 篇文章 0 订阅
1 篇文章 0 订阅

C - Lamps

题意

给定一个长度为n的序列 a i {a_i} ai,定义该 { a i } \{a_i\} {ai}序列对应的 { b i } \{b_i\} {bi}序列:
b i = ∑ j = 1 n [ j − a j ≤ i ≤ j + a j ] b_i=\sum\limits_{j=1}^n[j-a_j\leq i \leq j+a_j] bi=j=1n[jajij+aj](中括号内的值为真则为1否则为0)
现执行 k k k次操作,每次操作求出 { b i } \{b_i\} {bi}序列然后替换掉 { a i } \{a_i\} {ai}序列,求 k k k次操作后的 { a i } \{a_i\} {ai}序列。

思路

不超过大概 log ⁡ n \log n logn次操作后, { a i } \{a_i\} {ai}序列中每个数都变成n,直接模拟即可,当 { a i } \{a_i\} {ai}序列中每个数都变成n时可结束操作。

D - Knapsack Queries on a tree

题意

给定一颗节点数为 n n n的二叉树, 1 1 1为根节点,对于任意节点 i ( i ≥ 2 ) i(i \geq 2) i(i2)其父节点为 ⌊ i 2 ⌋ \lfloor \frac{i}{2} \rfloor 2i,每个节点有权值 v i v_i vi和重量 w i w_i wi。现有 q q q次查询,第i次查询格式为 v i v_i vi l i l_i li,表示在节点 v i v_i vi到根节点这一条链上的节点中,在重量总和不超过 l i l_i li的条件下,求权值之和的最大值。

思路

n \sqrt n n 个节点用dp求出背包数组,查询这些节点时 O ( 1 ) O(1) O(1)解答;
其他节点:
设树的深度为 d d d,对于每个查询,深度大于 d 2 \frac{d}{2} 2d的节点暴搜选或不选,深度小于 d 2 \frac{d}{2} 2d利用之前求得的背包数组,两部分之和求最大值。

E - O(rand)

题意

给出一个序列 { a i } \{a_i\} {ai},求该序列满足以下条件的子集数:

  1. 该子集所有数的 a n d and and运算结果为 s s s
  2. 该子集所有数的 o r or or运算结果为 t t t
  3. 子集大小不超过 k k k

思路

将数二进制下每一位分开考虑。显然 a n d and and运算结果和 o r or or运算结果分别为 0 0 0 1 1 1的情况无解。分两种情况考虑:

  1. 两种运算结果均为 0 0 0或均为 1 1 1,所选的数对应位必须为 0 0 0 1 1 1
  2. 两种运算结果分别为 0 0 0 1 1 1,那么所选的数至少有一个数对应位为 0 0 0,至少有一个数对应位为 1 1 1。考虑容斥,定义“子集 s s s i i i位不合法”:子集 s s s中所有数的第 i i i位均为 0 0 0或均为 1 1 1。那么总方案数为满足条件3.的子集数减去满足条件3.并且满足存在某位i不合法的子集数,容斥即可,满足条件3.的方案数可以用组合数来计算。
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值