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 ...
随机推荐
- Win10下安装Maven 配置环境变量 设置settings
一.下载.设置环境变量 下载页面:https://maven.apache.org/download.cgi 下载地址:https://mirrors.tuna.tsinghua.edu.cn/apa ...
- 从优秀到卓越:成为DevOps专家的7项软技能
在我的职业生涯中,遇见过许多专业人士,他们在技术上非常健全,对自己的领域和技术有很好的掌握和专业知识,但是由于缺乏软技能,他们错过了晋升.现场机会.高级技术面试以及职业生涯中的机会.很震惊吧,技术好却 ...
- 7 CSS选择器优先级
7 选择器优先级 所谓CSS优先级,即是指CSS样式在浏览器中被解析的先后顺序.样式表中的特殊性描述了不同规则的相对权重. /* !important > 行内样式>ID选择器 > ...
- Python实现聊天机器人接口封装部署
一.前言说明 博客声明:此文链接地址https://www.cnblogs.com/Vrapile/p/12427326.html,请尊重原创,未经允许禁止转载!!! 1. 功能简述 (1)将chat ...
- 今晚19:00知识赋能第2期直播丨OpenHarmony智能家居项目之控制面板界面设计
OpenAtom OpenHarmony(以下简称"OpenHarmony")开源开发者成长计划项目自 2021 年 10 月 24 日上线以来,在开发者中引发高度关注. 成长计划 ...
- 技术文档指南:版本说明、网站文案、FAQ、案例研究与内容优化
Release Notes 和产品公告 Release Notes 通常是软件文档的一部分,是在新产品发布时提供给用户的简短.高级摘要.它们包含有关更新的重要信息,包括新功能.增强功能.错误修复,通常 ...
- mysql 简单进阶 ———— 多列索引[一]
前文 整理一下mysql 的一些简单进阶技巧,来源于高性能mysql,但不是根据书的序列来的. 正文 库地址: https://dev.mysql.com/doc/index-other.html 有 ...
- 重学c#系列——DiagnosticListener [三十五]
前言 简单介绍一下DiagnosticListener,一个比较常见的事件通知模型,可以说是事件发布订阅模型,常用于监控. 正文 直接编写代码: using System.Diagnostics; p ...
- python mmsql连接支持
前言 因为我使用的是mmsql数据库,因为遇到一点坑,所以发布出来. 正文 准备工作: https://www.lfd.uci.edu/~gohlke/pythonlibs/#pymssql 下载对应 ...
- mysql 重新整理——索引简介[七]
前言 百度百科索引: 在关系数据库中,索引是一种单独的.物理的对数据库表中一列或多列的值进行排序的一种存储结构,它是某个表中一列或若干列值的集合和相应的指向表中物理标识这些值的数据页的逻辑指针清单. ...