Solution - AGC060B
简要题意:在 \(n \times m\) 的方格表中填入一些不超过 \(2^k-1\) 的数。考虑所有从左上角到右下角的最短路径,要求其中满足路径上数异或和为 \(0\) 的路径只有给定的 \(S\) 一条,问是否有解。
首先,变换看问题的角度:给定 \(n,m,S\),则 \(k\) 应该存在一个最小值,使得问题有解(或总是无解),所以这其实是一个组合最值问题。那么考虑两个方面:证明和构造。
证明部分,我们要尽可能的增大 \(k\),也就是增大所需的二进制位数。那么,考虑 \(S\) 的一个拐角,如图,红线表示 \(S\),蓝线表示一个调整。

这里拐角指的是红线的拐弯处斜向相邻的这个格,即图中蓝线唯一不同与红线的格。
将红线换为蓝线之后,只改变了两个格,那么由于蓝线不能异或和为 \(0\),所以这两个格至少有一位二进制不同。
这样的调整可以在若干个地方进行,设为 \(t\) 个,第 \(i\) 个调整会使路径的异或和改变 \(v_i\)。那么,不能有若干个 \(v_i\) 的异或和为 \(0\),即 \(v_i\) 是一个线性无关组。由于 \(v_i\) 定义在 \(k\) 位二进制数上,所以 \(t \le k\)。
但是,并不是每个拐角都可以调整。准确地说,不是所有拐角都可以一起调整。请看下图:

图中标出了三个拐角,但是显然不能同时做 \(1,2\) 的调整,也不能同时做 \(1,3\) 的调整。再思考一下可以发现,其实只有这样的一种情况是特殊的,也就是有一段经过两格的,连续的若干个两格只取一侧。
如此就可以算出 \(k\) 的下界,它其实就是一条路径能够经过的拐角数目的最大值,只是对于连续的两格比较特殊。
至于构造,思考到这里应该不太难了。方案如下:(想象一个人在表格中走,Ta要做一些决策)
对于一段长度大于等于 \(3\) 的直走,取新的一位,在这一段两端各添一个 \(1\)。这样可以使得走到这一段开头后必须走这一段结尾。
对于一些长度为 \(2\) 的直走,不妨设第一个 \(2\) 是竖向的,那么给每一段竖向的分配一个二进制位,在这两个格上添 \(1\)。然后取消两端由上一条添的位。
似乎说的不太清楚?上图。

在第二条规则下,有一些“必经之路”会被挡住,所以必须要经过所有安排的 \(1\)。
容易验证这个构造确实取到了前面证明的最值。
AGC 传统,思路难,代码易。请看 Code:
#include<bits/stdc++.h>
using namespace std;
int T,n,m,k,cnt,x,y,lstx,lsty;
//x,y跟着路径S跑
//lstx,lsty表示上一个选中的拐角
char s[65];
int main(){
scanf("%d",&T);
while(T--){
scanf("%d%d%d",&n,&m,&k);
scanf("%s",s+1);
cnt=0;x=y=lstx=lsty=1;
for(int i=1;i<n+m-2;i++){
if(s[i]=='D')x++;else y++;
if(s[i]!=s[i+1]){
if(s[i]=='D'&&lstx<=x-1&&lsty<=y+1)
cnt++,lstx=x-1,lsty=y+1;
if(s[i]=='R'&&lstx<=x+1&&lsty<=y-1)
cnt++,lstx=x+1,lsty=y-1;
}
}
printf(cnt<=k?"Yes\n":"No\n");
}
return 0;
}
Solution - AGC060B的更多相关文章
- Enterprise Solution 3.1 企业应用开发框架 .NET ERP/CRM/MIS 开发框架,C/S架构,SQL Server + ORM(LLBL Gen Pro) + Infragistics WinForms
行业:基于数据库的制造行业管理软件,包含ERP.MRP.CRM.MIS.MES等企业管理软件 数据库平台:SQL Server 2005或以上 系统架构:C/S 开发技术 序号 领域 技术 1 数据库 ...
- Enterprise Solution 开源项目资源汇总 Visual Studio Online 源代码托管 企业管理软件开发框架
Enterprise Solution 是一套管理软件开发框架,在这个框架基础上开发出一套企业资源计划系统Enterprise Edition. 现将Enterprise Solution开发过程中遇 ...
- Windows 10 部署Enterprise Solution 5.5
Windows 10正式版发布以后,新操作系统带来了许多的变化.现在新购买的电脑安装的系统应该是Windows 10.与当初用户不习惯Windows 7,购买新电脑后第一个想做的事情就是重装成XP,估 ...
- Enterprise Solution 企业资源计划管理软件 C/S架构,支持64位系统,企业全面应用集成,制造业信息化
Enterprise Solution是一套完整的企业资源计划系统,功能符合众多制造业客户要求.系统以.NET Framework技术作为开发架构,完善的功能可有效地帮助企业进行运营策划,减低成本,如 ...
- Dynamics CRM 2015-超大Solution导入问题
我们在将比较大的solution导入CRM的时候,经常会遇到超时的问题,这是因为CRM的本身的优化限制导致的,那么如何解决呢? 官方已经有了解决方案了. 在浏览完两种解决方法之后,我们要知道的是: 1 ...
- WATERHAMMER: A COMPLEX PHENOMENON WITH A SIMPLE SOLUTION
开启阅读模式 WATERHAMMER A COMPLEX PHENOMENON WITH A SIMPLE SOLUTION Waterhammer is an impact load that is ...
- Codility NumberSolitaire Solution
1.题目: A game for one player is played on a board consisting of N consecutive squares, numbered from ...
- codility flags solution
How to solve this HARD issue 1. Problem: A non-empty zero-indexed array A consisting of N integers i ...
- The Solution of UESTC 2016 Summer Training #1 Div.2 Problem C
Link http://acm.hust.edu.cn/vjudge/contest/121539#problem/C Description standard input/output After ...
- The Solution of UESTC 2016 Summer Training #1 Div.2 Problem B
Link http://acm.hust.edu.cn/vjudge/contest/121539#problem/B Description standard input/output Althou ...
随机推荐
- AXI-自定义IP-PS设计
基于AXI4的自定义IP核的设计 1.实验目标 利用vivado中内置的AXI总线初始化的IP核设计工具,将自己设计的流水灯的PL代码打包成IP核外设,挂在PS上,通过PS上的按钮控制流水灯的开始和结 ...
- springBoot打war包部署tomcat
1.修改maven的pom.xml文件 <packaging>war</packaging> 2.排除springboot内嵌的tomcat <dependency> ...
- KingbaseES生成动态SQL
1. 动态SQL 动态SQL在程序启动时会根据输入参数替换相应变量.使用动态SQL可以创建更强大和灵活的应用程序,但在编译时SQL语句的全文不确定,因此运行时编译会牺牲一些性能.动态SQL可以是代码或 ...
- 电影数据集【可供机器学习附爬虫源码】(豆瓣、爱奇艺、IMDB、腾讯视频等)
电影数据集(豆瓣.爱奇艺.IMDB.腾讯视频.搜狐.1905) 爬虫爬取豆瓣.爱奇艺.IMDB.腾讯视频.搜狐.1905网,电影数据. 获取方式:微信搜索关注[靠谱杨阅读人生]回复[电影]. 整理不易 ...
- 基于energy score的out-of-distribution数据检测,LeCun都说好 | NerulPS 2020
论文提出用于out-of-distributions输入检测的energy-based方案,通过非概率的energy score区分in-distribution数据和out-of-distribu ...
- list集合中的实现类LinkedList
LinkedList: 底层是一个双向链表,方便数据的频繁出入.便于快速插入,删除元素,不太方便进行查询 toArray(): 以正确的顺序(从第一个到最后一个素)返回一个包含此列表中所有元素的数组 ...
- CH395的FTP Server(主动模式)简单应用参考
FTP(File Transfer Protocol,文件传输协议) 是 TCP/IP 协议组中的协议之一.FTP协议包括两个组成部分,其一为FTP服务器,其二为FTP客户端.本篇文章将基于FTP协议 ...
- #点分树 or LCT#洛谷 4115 Qtree4
两次LCT的Access操作就可以求LCA啦 题目 给出一棵树,支持单点反色和查询全局最远白点 分析(点分树) 点分树的做法就是考虑点分树上的父亲把子树分成若干个部分, 那么所谓的白点直径可以把子树的 ...
- #倒推#洛谷 3998 [SHOI2013]发微博
题目 分析 考虑\(x\)看到\(y\)的消息条数等于互删时\(y\)发的消息条数减去互加时\(y\)发的消息条数 为了让最后\(x\)和\(y\)不再为好友,那可以将操作反过来,因为一开始他们一定不 ...
- OpenHarmony轻松玩转GIF数据渲染
OpenAtom OpenHarmony(以下简称"OpenHarmony")提供了Image组件支持GIF动图的播放,但是缺乏扩展能力,不支持播放控制等.今天介绍一款三方库--o ...