A. The Wall

  • 求下gcd即可。

B. Maximal Area Quadrilateral

  • 枚举对角线,根据叉积判断顺、逆时针方向构成的最大面积。
  • 由于点坐标绝对值不超过1000,用int比较快。

C. Tourist Problem

  • 假设序列为\(p_1,p_2,...,p_n\),则距离总和为\(,,,p_1,|p_2-p_1|,...,|p_n-p_{n-1}|\)。
  • 第1个点\(p_1\)的贡献为\(\sum a_i(n-1)!\)
  • \(|p_i-p_{i-1}|\)的贡献为\(|p_i-p_{i-1}|(n-1)(n-2)!\)
  • 对于\(a_i\)排序,可以计算所有\(p_i-p_{i-1},p_i>p_{i-1}\)的总和,乘以2即所有\(|p_i-p_{i-1}|\)的总和。

D. Bubble Sort Graph

  • 对于所有\(i<j, a_i>a_j\)的点对来说,冒泡排序最终都会交换这两个数,即存在连边。
  • 最大独立集显然就是最长上升序列的长度。

E. Iahub and Permutations

  • \(dp,O(n^2)\)做法:

    1. \(dp(n,k)\)表示有\(n\)个自由放置的数,\(k\)个限制放置的数。
    2. \(dp(n,0)=n!\),因为没有限制,所以方案数为\(n!\)
    3. \(dp(n,1)=n \cdot dp(n,0)\),限制的数有\(n\)个位置可以放置,剩余\(n\)个数全排列放置。
    4. \(dp(n,k)=n\cdot dp(n,k-1)+(k-1)\cdot dp(n+1,k-2)\),考虑其中一个限制的位置:选择自由元放置,则对应限制的数称为自由元。选择限制数放置,不能放置对应的数,所有\(k-1\)个,对应限制的数称为自由元。
  • 容斥\(O(n^2)\)做法:
    1. \(dp(i)\)表示有\(i\)个\(fixed\ point\)的方案数,\(tot\)表示空闲位置,\(fp\)表示最大数量。
    2. \(dp(i)=\binom{fp}{i}(tot-i)!-\sum_{j=i+1}^{fp}{dp(j)\binom{j}{i}}\)
  • \(dp,O(n)\)做法:
    1. \(dp(i)\)表示放置\(i\)个限制数的方案数。
    2. \(dp(0)=free!\),\(free\)表示自由元的数量。
    3. \(dp(1)=dp(0)*free\),当前自由元不能放置在本身位置,所以需要和一个自由元对换位置。
    4. \(dp(i)=free\cdot dp(i-1)+(i-1)\cdot(dp(i-2)+dp(i-1))\),\((i-1)dp(i-2)\)表示当前限制数和之前其中一个限制数两个互相占据彼此的位置,则变成放置\(i-2\)的子问题,否则如果没有对换位置,则变成\(i-1\)的子问题。

F. Iahub and Xors

  • 二维前缀异或和。
  • 修改单点\((x,y)\),会对\(,(x+2k,y+2k)\)所有前缀产生影响。
  • 根据\((x,y)\)的奇偶性,建4棵二维树状数组,容斥计算异或和以及更新前缀和。

G. Candies Game

  • 结论:任意三个数\(A,B,C\),都能通过若干次操作,使得其中一个数变成0。
  • 证明,以下考虑三个数都不相等的情况:
    1. 假设\(0<A<B<C\),则\(B=A\cdot q + r\),其中\(r<A\)。那么我们的目的就是把\(B\)转成\(r\),得到更小的三元组。
    2. \(q\)用二进制表示,则\(B=(2^{e_n}+2^{e_{n-1}}+…+2^{e_0})A+r\)。
    3. 从最低位考虑,若对应位置为\(1\),则\(q\)的二进制1的个数减少1,否则从\(C\)取出\(A\)放入\(A\)中。即\(A\)的值依次变成\(2^0A,2^1A,2^2A,…\),那么就能对应地把\(q\)的1全部去除,即$B'=r

Codeforces Round #198 (Div. 1 + Div. 2)的更多相关文章

  1. Codeforces Round #198 (Div. 2)A,B题解

    Codeforces Round #198 (Div. 2) 昨天看到奋斗群的群赛,好奇的去做了一下, 大概花了3个小时Ak,我大概可以退役了吧 那下面来稍微总结一下 A. The Wall Iahu ...

  2. Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - C. Magic Ship Time Limit: 2000 mSec P ...

  3. Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems(动态规划+矩阵快速幂)

    Problem   Educational Codeforces Round 60 (Rated for Div. 2) - D. Magic Gems Time Limit: 3000 mSec P ...

  4. Educational Codeforces Round 43 (Rated for Div. 2)

    Educational Codeforces Round 43 (Rated for Div. 2) https://codeforces.com/contest/976 A #include< ...

  5. Educational Codeforces Round 35 (Rated for Div. 2)

    Educational Codeforces Round 35 (Rated for Div. 2) https://codeforces.com/contest/911 A 模拟 #include& ...

  6. Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings

    Codeforces Educational Codeforces Round 44 (Rated for Div. 2) F. Isomorphic Strings 题目连接: http://cod ...

  7. Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes

    Codeforces Educational Codeforces Round 44 (Rated for Div. 2) E. Pencils and Boxes 题目连接: http://code ...

  8. Educational Codeforces Round 63 (Rated for Div. 2) 题解

    Educational Codeforces Round 63 (Rated for Div. 2)题解 题目链接 A. Reverse a Substring 给出一个字符串,现在可以对这个字符串进 ...

  9. Educational Codeforces Round 39 (Rated for Div. 2) G

    Educational Codeforces Round 39 (Rated for Div. 2) G 题意: 给一个序列\(a_i(1 <= a_i <= 10^{9}),2 < ...

  10. Educational Codeforces Round 48 (Rated for Div. 2) CD题解

    Educational Codeforces Round 48 (Rated for Div. 2) C. Vasya And The Mushrooms 题目链接:https://codeforce ...

随机推荐

  1. HTML小技巧:按钮中的文字换行 .

    一般按钮的文字都是一行的.但是有的时候画面需要按钮中的文字换行. 刚开始有个开发人员说没法实现.\r\n 都用过了没有效果.其实google这个老师是非常强大的. 直接换行的方法:<input ...

  2. JSP Web第八章整理复习 过滤器

    P269  Filter过滤器的基本原理 P269  Filter过滤器体系结构 原理和体系结构看懂了就行 P270 例8-1过滤器代码与配置文件 略

  3. TYVJ1340 送礼物

    P1340 送礼物 时间: 1000ms / 空间: 131072KiB / Java类名: Main 描述 作为惩罚,GY被遣送去帮助某神牛给女生送礼物(GY:貌似是个好差事)但是在GY看到礼物之后 ...

  4. 移动web的基础知识

    一.像素 px:CSS pixels逻辑像素,浏览器使用的抽象单位 dp,pt:设备无关像素 (物理像素) dpr:设备像素缩放比 计算公式: 1px = (dpr)*(dpr)*dp 二.viewp ...

  5. 阿里云MVP北京闭门会圆满落幕 多把“利剑”助力开发者破阵蜕变

    摘要: 从传统制造业到新零售,从人工智能到新金融,阿里云MVP正在成为中国乃至全球各行各业数字化转型的中坚力量.当这群技术先锋者与阿里核心技术力量汇聚在一起,一场无与伦比的思想碰撞就此展开. 3月21 ...

  6. Auto reloading enabled

    在eclipse中集成tomcat来开发时, 如果使用run as模式启动项目的话,tomcat配置Auto reloading enabled,我们修改java文件,项目会重新加载,修改的内容会生效 ...

  7. day39-Spring 04-CGLIB的动态代理

    JDK动态代理是有接口我给你创建一个类和你这个实现类是一样的, CGLIB不对实现接口的类生成代理,一个普通类也可以生成代理.CGLIB用继承的方式帮你生成代理对象.你父类有的方法我也有了,我想增强也 ...

  8. PHPCMS快速建站系列之pc:get标签的应用

    GET标签使用方式如下: {pc:get sql="SELECT * FROM phpcms_member" cache="3600" page="$ ...

  9. Laravel 单设备登录

    https://laravel-china.org/articles/10605/laravel-single-device-login 前几天在 laracasts 看了laravel5.6的新功能 ...

  10. 杨柳目-杨柳科-Info-新闻:注意了!杨絮解决有办法了

    ylbtech-杨柳目-杨柳科-Info-新闻:注意了!杨絮解决有办法了  1.返回顶部 1. 注意了!杨絮解决有办法了 2018-05-03 14:18 昨天中午经过一个理发店,门口蹲了个染黄发.系 ...