A@[G!C]%008


A Simple Calculator

细节题。

B Contiguous Repainting

最后只要有连续\(K\)个鸽子同色就可以构造方案,枚举+前缀和

C Tetromino Tiling

分析一波发现T,Z,S不可能出现,O可以直接加到最后面,剩下的拼法可以简化成JJ,II,LL,JIL,分类讨论一下。

D K-th K

直接贪心加

E Next or Nextnext

毒瘤神仙题

排列\(p\)会连成一些环,\(a\)是一个鸡环内向森林,考虑一个环怎么变化

变化的方式是每个点\(i\)可以将边\((i,p_i)\)变成\((i,p_{p_i})\),

  • 如果\(a\)是一个环,那么就是每个点的出边都变了或者都没变

    • 如果\(p\)是个奇环,那么\(a\)有两种方式(直接看题解的图)
    • 如果\(p\)是个偶环,那么\(a\)也有两种方式,要么不变要么拆成两个环长相等的环(直接看题解的图)

那么这个可以dp求出环的情况数

  • 如果\(a\)是个鸡环内向树,首先环上一个点最多接一条链,然后考虑相邻的两条链,如果满足一定大小关系就给答案×2(直接看题解)

https://agc008.contest.atcoder.jp/editorial

F Black Radius

这个题太仙了= =(yyb:然而我也不太会

部分分做法。。。现在所有点都可以是黑色

设\(f(x,d)\)为距离\(x\)不超过\(d\)的点集。这里钦定全集不计入答案,那么设\(max_i\)表示每个点的最远点距离,\(d_i<max_i\)

但是肯定会有记重,比如两个点\(x,y\),有\(f(x,d_x)=f(y,d_y)\)。容易证明如果有相邻的\(x,y\),\(f(x,d_x)=f(y,d_y)\)那么\(|d_x-d_y|=1\)(考虑一定存在一条边连接着一个被染黑和未染黑的点,走过去的步数差)

而且可能选了一个\(f(x,d_x)\)后,有一个连通块,在这个连通块里选一个\(y\)都能找到\(f(y,d_y)=f(x,d_x)\)(我也不知道为啥就是连通块)

而且连通块中一定可以找到唯一一个\(d\)最小的点,如果有两个,考虑一定存在一条边连接着一个被染黑和未染黑的点,讨论未染黑的点的位置,发现都不可能= =

于是就可以对每个\(f(x,d_x)\)相同的连通块,只在\(d\)最小的那个点记录,就可以不重不漏计数了。

具体的,记录\(f(x,d)\)时,如果有一个相邻的\(y\)满足\(f(x,d)=f(y,d-1)\),就不记录。

考虑对于\(x\),\(d\)要满足什么东西,首先\(d<max_x\),然后如果\(x\)设为树根,不存在儿子\(y\)满足不记录的条件。

首先\(y\)子树内的,\(f(x,d)\)该记到的\(f(y,d-1)\)都能记到,这个是一样的。其他子树中,因为从\(y\)出发过去会少记两层,所以其他子树中只要有一个满足\(f(y,d-1)\)没记完整个子树,这个\(y\)就不行。如果对\(x\)选尽量能淘汰\(x\)的\(y\)肯定选最长的链,设\(sec_i\)表示每个点设为根,所有儿子中\(max_{son}\)的次大值+1。要满足的是\(d<sec_x+2\)(再大就占满所有其他子树了)

然后一次换根dp就做完了部分分= =

考虑\(d\)的下界,如果一个点不能被染黑,它能计算的\(d\)下界是啥。

还是\(x\)作为根,只要\(d\)染黑了一整个儿子的子树,而且这个儿子中有能染黑的点就可以。

然而我也不太懂(抄题解)


https://agc008.contest.atcoder.jp/submissions/me?task_screen_name=&language_screen_name=&status=AC

A@[G!C]%008的更多相关文章

  1. Storyboards Tutorial 03

    这一节主要介绍segues,static table view cells 和 Add Player screen 以及 a game picker screen. Introducing Segue ...

  2. 文件图标SVG

    ​<svg xmlns="http://www.w3.org/2000/svg" xmlns:xlink="http://www.w3.org/1999/xlink ...

  3. [转]Linux下g++编译与使用静态库(.a)和动态库(.os) (+修正与解释)

    在windows环境下,我们通常在IDE如VS的工程中开发C++项目,对于生成和使用静态库(*.lib)与动态库(*.dll)可能都已经比较熟悉,但是,在linux环境下,则是另一套模式,对应的静态库 ...

  4. CentOS 6.6 升级GCC G++ (当前最新版本为v6.1.0) (完整)

    ---恢复内容开始--- CentOS 6.6 升级GCC G++ (当前最新GCC/G++版本为v6.1.0) 没有便捷方式, yum update....   yum install 或者 添加y ...

  5. Linux deepin 下sublimes配置g++ openGL

    参考 :http://blog.csdn.net/u010129448/article/details/47754623 ubuntu 下gnome只要将代码中deepin-terminal改为gno ...

  6. [翻译svg教程]svg 中的g元素

    svg 中的<g>元素用来组织svg元素.如果一组svg元素被g元素包裹了,你可以通过对g元素进行变换(transform),被g元素包裹的元素也将被变换,就好这些被svg包裹的元素是一个 ...

  7. 软件工程:黄金G点小游戏1.0

    我们要做的是黄金G点小游戏: N个同学(N通常大于10),每人写一个0~100之间的有理数 (不包括0或100),交给裁判,裁判算出所有数字的平均值,然后乘以0.618(所谓黄金分割常数),得到G值. ...

  8. 2016huasacm暑假集训训练五 G - 湫湫系列故事——减肥记I

    题目链接:http://acm.hust.edu.cn/vjudge/contest/126708#problem/G 这是一个01背包的模板题 AC代码: #include<stdio.h&g ...

  9. 毫秒级的时间处理上G的图片(生成缩略图)

    测试环境: 测试图片(30M): 测试计时方法: Stopwatch sw1 = new Stopwatch(); sw1.Start(); //TODO...... sw1.Stop(); stri ...

随机推荐

  1. c# Windows服务管理

    .NET Framework中提供的类库可以很方便的实现对windows服务的安装.卸载.启动.停止.获取运行状态等功能.这些类都在System.ServiceProcess命名空间下. 所以,在开始 ...

  2. 网络编程之基于UDP协议的套接字编程、基于socketserver实现并发的socket

    目录 基于UDP协议的套接字编程 UDP套接字简单示例 服务端 客户端 基于socketserver实现并发的socket 基于TCP协议 server类 request类 继承关系 服务端 客户端1 ...

  3. Win10 资源管理器窗口无边框的问题

    将“在窗口下显示阴影”关闭,再重新打开即可. 等了这么久,才敢在工作环境使用Win10,没想到还是这么多bug和不方便之处:输入法.托盘区.蓝屏...

  4. 【MySQL】mysql中的锁机制

    一.分类 MySQL的锁机制不同的存储引擎支持不同的锁机制,分为表级锁.行级锁.页面锁.MyISAM和MEMORY存储引擎采用的是表级锁(table-level locking):BDB存储引擎采用的 ...

  5. 半导体行业MES系统应用案例

    半导体行业的发展是受惠在集成电路上的,但是收到技术瓶颈的阻碍,所以工业时期对半导体行业就造成了严重的冲击. 为了推动半导体行业快速发展,扭转像IBM.东芝以及富士康等IDM大厂利用晶圆代工对半导体制造 ...

  6. Cheat Engine 自动注入

    打开游戏 引用自动注入 选择跳转地址 CEAA脚本自动生成 红色部分就是添加代码的地方 添加代码 让阳光每次减少0,并且分配到作弊表 进行激活测试 发现阳光果然只增不减了

  7. sql 使用条件

    group by 1.在属性中出现相同内容的时候可以使用 2.也可以用来排序desc   asc 批量插入数据 INSERT into 表(属性)(select *from 表) INSERT int ...

  8. Golang: 模拟搜索引擎爬虫

    最近网站需要针对百度做 SEO 优化,用 Go 语言写了个测试程序,模拟一下百度的爬虫,看看返回的内容是否正确. 代码很简单,就是发送一个请求,把百度相关的信息放入请求头中即可,代码如下: packa ...

  9. jperf windows

    jperf windows版是款简单实用的网络性能测试的工具:它也是款图形界面的iperf程序,可以这进行使用JPerf程序的时候,快速的进行简化您的命令行参数,而且这进行测试结束之后,还是以图形化的 ...

  10. Virtualbox 设置虚拟机和物理机共享文件夹

    Virtualbox 设置虚拟机和物理机共享文件夹 概述 当我们在本地机安装好一个虚拟机后,特别是安装linux系统的朋友们,经常需要将本地机的文件传递到虚拟机中, 能实现的方式肯定是多式多样的,就本 ...