(比赛链接)[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树结构路径查找

    var a=[ { "id" : "0000", "text" : "R1", "children" ...

  2. javac与java版本不一致

    项目测试时遇到该问题,因为loadRunner不支持jdk1.7,但运行java脚本时提示jdk版本是1.7,实际的JAVA_HOME设置为1.6. 运行javac -version与java -ve ...

  3. stark组件配置,二层URL

    1.django的admin配置 2 stark组件开发 3.2层url分发 4.小结 1.django的admin配置 model.py from django.db import models # ...

  4. Python3练习题 021:递归方法求阶乘

    利用递归方法求5!. 方法一 f = 1 for i in range(1,6):     f = f * i print(f)   方法二 import functools print(functo ...

  5. PropertyChangeSupport 监听器模式的应用

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

  6. [转帖]Docker save and load镜像保存

    Docker save and load镜像保存 https://www.cnblogs.com/zhuochong/p/10064350.html docker save 和 load 以及 imp ...

  7. java的强制类型转换

    java强制类型转换  详细连接https://www.cnblogs.com/kuangwong/p/6198862.html 在Java项目的实际开发和应用中,常常需要用到将对象转为String这 ...

  8. SOAP-ERROR: Encoding: string … is not a valid utf-8 string

    今天遇到一个错误,看标题就知道是什么错误了.... 最坑爹的是,不是所有的用户会报这个错误.只有少部分.在生产环境又没办法调试. 找了半天都不知道什么原因,字面意思大概是需要一个utf8编码的字符串, ...

  9. Selenium简单回顾

    一.Selenium介绍 1.Selenium(浏览器自动化测试框架): Selenium 是一个用于Web应用程序测试的工具.Selenium测试直接运行在浏览器中,就像真正的用户在操作一样.支持的 ...

  10. CSS3圆角详解(border-radius)

    1.CSS3圆角的优点 传统的圆角生成方案,必须使用多张图片作为背景图案.CSS3的出现,使得我们再也不必浪费时间去制作这些图片了,而且还有其他多个优点: 减少维护的工作量.图片文件的生成.更新.编写 ...