1929. 镜子田地
题目链接
1929. 镜子田地
农夫约翰在屋子外面放了一些旧镜子,他的奶牛们像往常一样调皮地偷走了它们!
奶牛们将镜子放置在了一个矩形田地中,该田地可被划分为 个方格区域。
在每个方格区域中,奶牛在其某对对角之间放置一个双面镜,因此,共有两种放法,一种为 /
放置(镜子连接方格左下角和右上角),另一种为 \
放置(镜子连接方格左上角和右下角)。
一天晚上,奶牛贝茜将激光发射器带到了该田地中。
她站在田地外面,沿着田地的行或列水平或垂直照射光束,使光束反射一定数量的镜子。
由于镜子都是沿对角线摆放,因此经反射镜反射的水平光束最终将垂直传播,反之亦然。
贝茜想知道从田地之外射入的水平或垂直光束最多可以在田地中被反射多少次。
给定镜子田地的布局,请帮助贝茜计算这个数字。
输入格式
第一行包含 和 。
接下来 行,每行包含 个 /
或 \
字符,表示田地中镜子的具体摆放方式。
输出格式
输出田地之外的水平或垂直光束能够被反射的最大次数。
如果可以无限反射,则输出 。
数据范围
输入样例:
输出样例:
样例解释
贝茜可以从上向下沿中间列上方发射激光。
共可以反射 次。
解题思路
环图:对于无向图来说,所有点的度数小于等于 ,这个图由若干条链和简单环构成
不妨将每个格子内部分为两个结点;
对于内部的结点来说每个结点的度数为 ,而对于边界结点,其度数为 或 (当且仅当在对角上且对角线与镜子垂直时其度数才为 ),则其为环图,由于光线从外部射入,所以光线不可能是个环,只能是条链,对此可暴力求解,即从每个边界结点出发求解。
另外,这里方向用到了一些技巧:
以/
为例:
最后转移的方向为:
同理/
转移的方向为: 或
代码
__EOF__

本文作者:acwing_zyy
本文链接:https://www.cnblogs.com/zyyun/p/15845223.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
本文链接:https://www.cnblogs.com/zyyun/p/15845223.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是博主的最大动力!
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· 单线程的Redis速度为什么快?
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 展开说说关于C#中ORM框架的用法!