(比赛链接)[https://www.nowcoder.com/acm/contest/177#question]

T1

(题目链接)[https://www.nowcoder.com/acm/contest/177/A]

首先考虑二维前缀和
[l1, r1], [l2, r2]的解
即ans([0, r1], [0, r2]) - ans([0, l1 - 1], [0, r2]) - ans([0, l2 - 1], [0, r1]) + ans([0, l1 - 1], [0, l2 - 1])

对于最简单的情况
即 r1 = r2 = 2^n - 1(所有的都是闭区间)
组成一个数有2^n - 1中方案
那么只需统计有多少个m的倍数小于2^n

如果r1 = 2^k - 1, r2 = 2^n - 1
组成一个数一共有2^k - 1种方案
那么只需统计有多少个m的倍数小于2^k

对于更普遍的情况 比如r1 = 1010
我们可以把r1 + 1即1011拆成一堆比它小的数
0*** 100* 1010
这样就涵盖了所有小于等于r1的情况
打星号处可以随便填,一共可以分成log种类型
这样的话就有log(r1)组和log(r2)组相互匹配
对于其中一组 a1(2^p) +(p位的随机),a2(2^q) + (q位的随机)
那么它们可以构成的数就是(a1(2^p)) & (a2(2^q)) + (p位随机)
然后判(a1(2^p)) & (a2(2^q))到(a1(2^p)) & (a2(2^q)) + (2^(max(p, q) + 1) - 1)里面有多少个m的倍数就可以了

注意随时取模!模 *不模 = 爆炸

T2

(题目链接)[https://www.nowcoder.com/acm/contest/177/B]

对与这样一张图 设一个边被经过的次数为t[] 我们可以证明如下点
1.所有t[i] > 1的边一定在MST上
2.所有t[i] <= 2

结论一是来自这道题特du别liu的边权设定
使致一个环上最大那条边的边权 大于环上其他边的边权和

对于结论二的证明
对于一条被经过k次的边 就像相当于在这两点间连k条边
然后走的是个欧拉回路 而欧拉回路上每个点的度数为偶数
要是一条边被经过两次以上 比如3次 那么就和经过一次没区别
同理 偶数次和经过2次相同

对于图上奇偶 我们的日tao常lu处理方法就是 抑或
我们建一棵MST 统计好每一个点的度数 根据奇偶性染色
然后从叶子到根调节每条边经过次数 使得每个点的度数为偶数

注意if(vv != fa)dfs(); 哒哒哒。。。
后面的东西是会执行的! 需要continue掉!

T3

(题目链接)[https://www.nowcoder.com/acm/contest/177/C]

把s当作是t加入一些0、1形成的
t由c个0,d个1组成
那么就有c + d + 1个空隙可以填数

但是这样会重哦

那么 对于一个被构成的序列u 我们认为他是可以被记录的
当且仅当原来的s在u中是最靠前的一个为s的子串
比如 在101的第一个1和0之间加一个0 所得串就不可以被记录
因为原来的s在u中的位置是{1, 3, 4}而{1, 2, 4}也是与s相同的子串 并且比原来的s靠前
但在第二个0和1之间加一个0 所得串可以被记录

所以我们发现 在1前面不能加1 在0前面不能加0 但在最后可以随便加
所以枚举在最后加了x个0,y个1
即为在d+1个空里插a-c-x个0, 在c+1个空里插b-d-y个1(最后一个空两个都能放)
之后就是个插xiao板ao了
对于每个x和y 共可以构成C(a-c-x+d-1, d-1)C(b-d-y+c-1, c-1)C(x+y, x)个串
对于每组(x, y)求和即为答案

nowcoder提高集训营第5场的更多相关文章

  1. 牛客提高集训营6 C 树(树链剖分)

    题目链接 为了纪(zhuang)念(bi)写完这个树剖单独写一篇.感觉还好,也就6k嘛. 完整比赛题解:https://www.cnblogs.com/SovietPower/p/9826829.ht ...

  2. 牛客网NOIP赛前集训营 第6场 T1 最长路

    [题解] 先建反向图,然后跑拓扑排序求出最长路. 将所有的点按照最长路从小到大分层,把上一层连向这一层的边按照边权为第一关键字.起点的排名为第二关键字排序. 按照这个顺序更新这一层的答案,按照这一层每 ...

  3. 牛客网NOIP赛前集训营-普及组(第二场)和 牛客网NOIP赛前集训营-提高组(第二场)解题报告

    目录 牛客网NOIP赛前集训营-普及组(第二场) A 你好诶加币 B 最后一次 C 选择颜色 D 合法括号序列 牛客网NOIP赛前集训营-提高组(第二场) A 方差 B 分糖果 C 集合划分 牛客网N ...

  4. 牛客网NOIP赛前集训营-提高组(第四场)游记

    牛客网NOIP赛前集训营-提高组(第四场)游记 动态点分治 题目大意: \(T(t\le10000)\)组询问,求\([l,r]\)中\(k(l,r,k<2^{63})\)的非负整数次幂的数的个 ...

  5. 牛客网NOIP赛前集训营-提高组(第四场)B区间

    牛客网NOIP赛前集训营-提高组(第四场)B区间 题目描述 给出一个序列$ a_1  \dots   a_n$. 定义一个区间 \([l,r]\) 是好的,当且仅当这个区间中存在一个 \(i\),使得 ...

  6. 牛客网NOIP赛前集训营-提高组(第四场)B题 区间

    牛客网NOIP赛前集训营-提高组(第四场) 题目描述 给出一个序列 a1, ..., an. 定义一个区间 [l,r] 是好的,当且仅当这个区间中存在一个 i,使得 ai 恰好等于 al, al+1, ...

  7. 牛客网CSP-S提高组赛前集训营Round4

    牛客网CSP-S提高组赛前集训营 标签(空格分隔): 题解 算法 模拟赛 题目 描述 做法 \(BSOJ6377\) 求由\(n\)长度的数组复制\(k\)次的数组里每个连续子序列出现数字种类的和 对 ...

  8. 牛客CSP-S提高组赛前集训营1

    牛客CSP-S提高组赛前集训营1 比赛链接 官方题解 before:T1观察+结论题,T2树形Dp,可以换根或up&down,T3正解妙,转化为图上问题.题目质量不错,但数据太水了~. A-仓 ...

  9. Nowcoder 提高组练习赛-R7

    Nowcoder 提高组练习赛-R7 https://www.nowcoder.com/acm/contest/179#question 中间空了两场,因为实在是太难了... 第五场的第二题好像还比较 ...

随机推荐

  1. js中的join(),reverse()与 split()函数用法解析

    <script> /* * 1:arrayObject.reverse() * 注意: 该方法会改变原来的数组,而不会创建新的数组.此函数可以将数组倒序排列 * 2:arrayObject ...

  2. mysql 中Varchar 与char的区别

    一.字符与字节与编码关系 ASCII码中,一个英文字母(不分大小写)占一个字节的空间,一个中文汉字占两个字节的空间.一个二进制数字序列,在计算机中作为一个数字单元,一般为8位二进制数,换算为十进制.最 ...

  3. org.apache.ibatis.exceptions.PersistenceException: ### Error querying database. Cause: com.mysql.jdbc.exceptions.jdbc4.MySQLSyntaxErrorException: You have an error in your SQL syntax; check the manu

    这个是sql 语句 错误     仔细检查 SQL语句是否写错了 org.apache.ibatis.exceptions.PersistenceException: ### Error queryi ...

  4. Java参数是值传递还是引用传递?

    先来看看参数是如何传递的. 一.参数的传递 1.基本类型的参数传递 public static void main(String[] args) { int a = 1; fun(a); } priv ...

  5. git reset的用法

    git reset三个选项 --mix,--hard,--soft 数据 针对每个选项都是操作这个文件. [root@centos demo]# git init Initialized empty ...

  6. Python3练习题 006 冒泡排序

    import random a = [random.randint(1,100) for i in range(10)]def bu(target): length = len(target) whi ...

  7. js 移动端 多图上传 预览 删除 base64转为url 传给后端

    说下主要的逻辑,首先是利用input type="file",上传文件,然后判断文件类型是否是图片,这里要注意(multiple,安卓一次一张,ios可以多张). 接着把本地图片转 ...

  8. scroll滚动条样式修改

    一般我们有两种情况会出现滚动条,一种是overflow,一种是使用scroll. 当我们需要改变这个滚动条样式的时候,我们需要做以下的修改: html: <div id="style- ...

  9. PropertyChangeSupport 监听器模式的应用

    PropertyChangeSupport 类实现的监听器功能 ,它是java jdk自带的一个类,用于监听某个对象属性的改变来触发相应信息,具体看代码介绍 import java.beans.Pro ...

  10. [转帖]Docker 清理占用的磁盘空间

    Docker(二十七)-Docker 清理占用的磁盘空间 https://www.cnblogs.com/zhuochong/p/10076599.html docker system docker ...