11.04Test

查看请点个赞

转载请注明出处(不然)

题目 描述 做法
\(BSOJ5143\) 要求给\(M\)个通道染色,使得同色通道不能相交 转为矛盾模型,\(2-sat\)or二分图染色解决
\(BSOJ5145\) 多次加边,维护两点所在点双联通分量大小 \begin{cases}在线:LCT+并查集\离线:直接用并查集来"缩点"\end{cases}
\(BSOJ4932\) 用\(m\)色染\(n\)格子:求染出结果方案数 以匹配数为状态设计\(dp\)再改设状态中点为色块

\(\text{Day1}\)

\(T1\)

n个天使排成一条直线,某些天使之间需要互相联系,他们之间的通讯可以通过黑白两种通道中的一种;所有通道必须在直线同侧(另一侧是地面);为了保证通讯效率,同种颜色的所有通道之间不能相交。请计算能否建立这种通讯方案。

转问题为矛盾模型:相交的两个区间颜色必须不同

因此用\(2-sat\)和二分图染色均可

注意图可以不连通

\(T2\)

在遥远的S星系中一共有N个星球,编号为1…N。其中的一些星球决定组成联盟,以方便相互间的交流。

  但是,组成联盟的首要条件就是交通条件。初始时,在这N个星球间有M条太空隧道。每条太空隧道连接两个星球,使得它们能够相互到达。若两个星球属于同一个联盟,则必须存在一条环形线路经过这两个星球,即两个星球间存在两条没有公共隧道的路径。

  为了壮大联盟的队伍,这些星球将建设P条新的太空隧道。这P条新隧道将按顺序依次建成。一条新轨道建成后,可能会使一些星球属于同一个联盟。你的任务是计算出,在一条新隧道建设完毕后,判断这条新轨道连接的两个星球是否属于同一个联盟,如果属于同一个联盟就计算出这个联盟中有多少个星球。

这里着重讲离线

首先什么时候输出\(No\)

是在询问中一条边合并两个不连通集合

因此我们考虑一次把所有边加进去,当他可以合并两个集合时才真加

那么最后被加进去的询问边就是这样的合并两个不连通集合的边

因为在它之前没有边做到这一点

然后一条边联通现在点双联通分量形成的树上路径

然后把这条路径上的点缩成一个点双联通分量

这个可以用并查集实现

inline void Merge(re int x,re int y){
x=getf(x);y=getf(y);
while(x!=y){
if(dep[x]<dep[y])swap(x,y);
size[getf(rt[x])]+=size[x];x=fa[x]=fa[rt[x]];//向上合并
}
}

\(T3\)(JZOJ6303)

考虑颜色按顺序覆盖是什么意思

那就是一种颜色可以连着出现一段,中间包住一些颜色,然后后面出现一段

但注意,如果\(A\)颜色第一次出现的位置比\(B\)颜色的早,那么\(A\)颜色最后一次出现的位置比\(B\)颜色的晚(类似一个颜色栈)

因此我们在\(dp\)设计中加入一维\(k\)表示栈中还剩\(k\)中颜色或者还剩\(k\)中元素可以延续(注意一点:只要有颜色这个值就$\ge$1)

设\(\displaystyle{dp_{i,j,k}}\)表示有\(i\)个点,\(j\)种颜色曾进过栈,栈中还剩\(k\)中颜色

则\(dp_{i,j,k}\)可以由以下这些状态转移来

\[\begin{cases}dp_{i-1,j,k}&表示扩展一格最后的那种颜色(不结束)\\dp_{i-1,j,k+1}&表示用一个栈内元素(不一定相邻)来结尾这个颜色(出栈)\\dp_{i-1,j-1,k-1}&表示新开一个颜色,并且入栈(以后继续扩展)\\dp_{i-1,j-1,k}&表示新开一个颜色,不入栈(只用这一次)\end{cases}
\]

结合上元素选取的方案

自己推式子!!!

\(dp_{i,j,k}=dp_{i-1,j,k}+dp_{i-1,j,k+1}+(m-j+1)\times(dp_{i-1,j-1,k-1}+dp_{i-1,j-1,k})\)

考虑瓶颈在于第一句话\(dp_{i,j,k}=dp_{i-1,j,k}\)继承连续一段的信息,而其他均为新开或结束一段

复杂度为\(O(nm^2)\)

因此段和点实际上是等价

因此不如改状态为设\(\displaystyle{dp_{i,j,k}}\)表示有\(i\)个段(连续颜色),\(j\)种颜色曾进过栈,栈中还剩\(k\)中颜色

那么因为段数\(\le 2m\)

复杂度为\(O(m^3)\)

\(dp_{i,j,k}=dp_{i-1,j,k+1}+(m-j+1)\times(dp_{i-1,j-1,k-1}+dp_{i-1,j-1,k})\)

不放代码了,因为初始条件总该自己推把

11.04Test的更多相关文章

  1. 地区sql

    /*Navicat MySQL Data Transfer Source Server : localhostSource Server Version : 50136Source Host : lo ...

  2. WinForm 天猫2013双11自动抢红包【源码下载】

    1. 正确获取红包流程 2. 软件介绍 2.1 效果图: 2.2 功能介绍 2.2.1 账号登录 页面开始时,会载入这个网站:https://login.taobao.com/member/login ...

  3. C++11特性——变量部分(using类型别名、constexpr常量表达式、auto类型推断、nullptr空指针等)

    #include <iostream> using namespace std; int main() { using cullptr = const unsigned long long ...

  4. CSS垂直居中的11种实现方式

    今天是邓呆呆球衣退役的日子,在这个颇具纪念意义的日子里我写下自己的第一篇博客,还望前辈们多多提携,多多指教! 接下来,就进入正文,来说说关于垂直居中的事.(以下这11种垂直居中的实现方式均为笔者在日常 ...

  5. C++ 11 多线程--线程管理

    说到多线程编程,那么就不得不提并行和并发,多线程是实现并发(并行)的一种手段.并行是指两个或多个独立的操作同时进行.注意这里是同时进行,区别于并发,在一个时间段内执行多个操作.在单核时代,多个线程是并 ...

  6. CSharpGL(11)用C#直接编写GLSL程序

    CSharpGL(11)用C#直接编写GLSL程序 +BIT祝威+悄悄在此留下版了个权的信息说: 2016-08-13 由于CSharpGL一直在更新,现在这个教程已经不适用最新的代码了.CSharp ...

  7. ABP(现代ASP.NET样板开发框架)系列之11、ABP领域层——仓储(Repositories)

    点这里进入ABP系列文章总目录 基于DDD的现代ASP.NET开发框架--ABP系列之11.ABP领域层——仓储(Repositories) ABP是“ASP.NET Boilerplate Proj ...

  8. C++11 shared_ptr 智能指针 的使用,避免内存泄露

    多线程程序经常会遇到在某个线程A创建了一个对象,这个对象需要在线程B使用, 在没有shared_ptr时,因为线程A,B结束时间不确定,即在A或B线程先释放这个对象都有可能造成另一个线程崩溃, 所以为 ...

  9. C++11网络编程

    Handy是一个简洁优雅的C++11网络库,适用于linux与Mac平台.十行代码即可完成一个完整的网络服务器. 下面是echo服务器的代码: #include <handy/handy.h&g ...

随机推荐

  1. golang知识精要(二)

    类型 go是**静态类型**语言,不能在运行期改变变量类型. 变量定义 使用var定义变量,自动初始化为零值: 如果提供初始值,可省略变量类型: 函数内部可使用:=定义变量. var x int // ...

  2. Windows server 2012 显示“我的电脑”

    Windows server 2012 桌面上默认没有显示“我的电脑”的快捷方式, 如果要显示,可以输入一行命令: rundll32.exe shell32.dll,Control_RunDLL de ...

  3. ASP.NET Core中如何显示[PII is hidden]的隐藏信息

    有时候我们在ASP.NET Core项目运行时,发生在后台程序中的错误会将关键信息隐藏为[PII is hidden]这种占位符,如下所示: 而知道这些关键信息,有时候对我们调试程序是非常重要的.所以 ...

  4. C#读写设置修改调整UVC摄像头画面-光圈

    有时,我们需要在C#代码中对摄像头的光圈进行读和写,并立即生效.如何实现呢? 建立基于SharpCamera的项目 首先,请根据之前的一篇博文 点击这里 中的说明,建立基于SharpCamera的摄像 ...

  5. winform datagridview控件使用

    最近做项目时,显示查询结果总需要绑定到datagridview控件上显示,总结了给datagridview绑定数据的方式,以及导出datagridview数据到excel表格,如有错误请多指教 1.直 ...

  6. 第一章 Maven 安装配置

    Maven基于(POM)项目对象模型,通过一小段描述信息来管理项目的构建.文档.和报告的项目管理软件,类似于php 的管理构建工具composer. 有关详细的Maven学习,可以参考学习https: ...

  7. vue-awesome-swiper兼容ie9

    轮播插件vue-awesome-swiper在ie9中运行的时候没效果 解决方法: vue-awesome-swiper在IE9下报错, 主要原因是element.classlist.add()方法在 ...

  8. Sass和Less的区别?

    这篇文章主要解答以下几个问题,供前端开发者的新手参考. 1.什么是Sass和Less? 2.为什么要使用CSS预处理器? 3.Sass和Less的比较 4.为什么选择使用Sass而不是Less? 什么 ...

  9. AM335X UBOOT(以UART为例分析UBOOT主要流程)

    UBOOT2016.05 UART初始化及设置 SPL阶段 第一部分C函数 |- s_init //(arch/arm/cpu/armv7/am33xx/board.c) |- set_uart_mu ...

  10. VUE router-view key 属性解释

    router-view 作用, 你可以 router-view 当做是一个容器,它渲染的组件是你使用 vue-router 指定的. <template> <section clas ...