[Codeup 25481] swan
莫名其妙还找到了另一个铟炔锶烃的OJ : Codeup墓地
25481: swan
时间限制: 1 Sec 内存限制: 128 MB
献花: 86 解决: 13
[献花][花圈][TK题库]题目描述
两头白天鹅生活在一个部分湖面结了冰的湖泊中,湖面的形状为一个长方形,并且被分割成R行C列的小方格,某些方格中结了冰,这样的方格称之为冰格,其余的方格称之为水格。
冬天过去了,湖面上的冰渐渐开始溶解了,每一天与水相邻的冰格就将消融而转化为水格。所谓两个方格相邻是指它们在水平或垂直方向有公共边,两个呈对角的方格是不相邻的,下图给出样例数据的演化过程。
白天鹅只能在水中沿水平或垂直方向游动,写一个程序判断多少天后两只白天鹅才能够相会。
输入
输入文件第一行包含两个用空格隔开的整数R 和C,其中1≤R,C≤1500,接下来的R行每行包含C个字符,描述湖面的初始状态,‘·’表示水格,‘X’表示冰格,‘L’表示一只白天鹅。输出
输出文件仅一行包含一个整数表示两只白天鹅等到相邻那一天所需的天数。样例输入
8 17
...XXXXXX..XX.XXX
....XXXXXXXXX.XXX
...XXXXXXXXXXXX..
..XXXXX.LXXXXXX..
.XXXXXX..XXXXXX..
XXXXXXX...XXXX...
..XXXXX...XXX....
....XXXXX.XXXL...样例输出
2
首先我们可以看到这个动态消融的过程非常铟炔锶烃, 但是仔细想想后我们发现, 每块冰都有一个固定的消融时刻, 而这个时刻可以通过BFS预处理出来.
预处理的方式是将所有水方块入队, 每次取队首结点更新其相邻结点, 更新后新结点入队. 处理直至队列为空.
从一个 $L$ 到另一个 $L$ 中的路径中的结点的融化时间的最大值即为此条路径可用的时间. 而我们的任务实际上就是找到最早可用的路径的可用时刻.
所以这个问题似乎就变成了最短路问题. 不过不同的是平常的最短路是最小化边权/点权的和, 而这次我们要最小化的是路径中边权/点权的最大值. 这种时候不用方, 祭出我们万能的OI三大玄学之一 $SPFA$ 来跑一遍就得出解了OwO
(原题似乎丧病地卡了 std::queue ...给出题人 $2147483647$ 个差评(╯‵□′)╯︵┻━┻然而懒得实现循环队列就开了 $30M$ 个结构体, 每个结构体里两个 int ...(炸内存边缘))
参考代码
#include <queue>
#include <cstdio>
#include <cstring>
#include <cstdlib>
#include <iostream>
#include <algorithm> const int MAXN=; struct Point{
int x;
int y;
Point(int x=,int y=){
this->x=x;
this->y=y;
}
}; int n;
int m;
int l=,r=;
int xa,ya,xb,yb;
Point q[];
int dis[MAXN][MAXN];
int melt[MAXN][MAXN];
bool visited[MAXN][MAXN]; void BFS();
void gch(char&);
void Initialize();
void SPFA(int,int); int main(){
Initialize();
BFS();
SPFA(xa,ya);
printf("%d\n",dis[xb][yb]);
return ;
} void SPFA(int x,int y){
memset(visited,,sizeof(visited));
dis[x][y]=;
q[r++]=(Point(x,y));
visited[x][y]=true;
while(l<r){
x=q[l].x;
y=q[l].y;
l++;
visited[x][y]=false;
if(x>&&dis[x][y]<dis[x-][y]&&dis[x-][y]!=melt[x-][y]){
dis[x-][y]=std::max(dis[x][y],melt[x-][y]);
if(!visited[x-][y]){
visited[x-][y]=true;
q[r++]=(Point(x-,y));
}
}
if(x<n&&dis[x][y]<dis[x+][y]&&dis[x+][y]!=melt[x+][y]){
dis[x+][y]=std::max(dis[x][y],melt[x+][y]);
if(!visited[x+][y]){
visited[x+][y]=true;
q[r++]=(Point(x+,y));
}
}
if(y>&&dis[x][y]<dis[x][y-]&&dis[x][y-]!=melt[x][y-]){
dis[x][y-]=std::max(dis[x][y],melt[x][y-]);
if(!visited[x][y-]){
visited[x][y-]=true;
q[r++]=(Point(x,y-));
}
}
if(y<m&&dis[x][y]<dis[x][y+]&&dis[x][y+]!=melt[x][y+]){
dis[x][y+]=std::max(dis[x][y],melt[x][y+]);
if(!visited[x][y+]){
visited[x][y+]=true;
q[r++]=(Point(x,y+));
}
}
}
} void BFS(){
memset(visited,,sizeof(visited));
while(l<r){
int x=q[l].x;
int y=q[l].y;
++l;
if(x>&&!visited[x-][y]&&melt[x][y]+<melt[x-][y]){
melt[x-][y]=melt[x][y]+;
visited[x-][y]=true;
q[r++]=(Point(x-,y));
}
if(x<n&&!visited[x+][y]&&melt[x][y]+<melt[x+][y]){
melt[x+][y]=melt[x][y]+;
visited[x+][y]=true;
q[r++]=(Point(x+,y));
}
if(y>&&!visited[x][y-]&&melt[x][y]+<melt[x][y-]){
melt[x][y-]=melt[x][y]+;
visited[x][y-]=true;
q[r++]=(Point(x,y-));
}
if(y<m&&!visited[x][y+]&&melt[x][y]+<melt[x][y+]){
melt[x][y+]=melt[x][y]+;
visited[x][y+]=true;
q[r++]=(Point(x,y+));
}
}
} void Initialize(){
char ch;
memset(dis,0x3F,sizeof(dis));
memset(melt,0x3F,sizeof(melt));
scanf("%d%d",&n,&m);
for(int i=;i<=n;i++){
for(int j=;j<=m;j++){
gch(ch);
if(ch=='.'){
q[r++]=(Point(i,j));
melt[i][j]=;
visited[i][j]=true;
}
else if(ch=='L'){
q[r++]=(Point(i,j));
melt[i][j]=;
visited[i][j]=true;
if(xa==){
xa=i;
ya=j;
}
else{
xb=i;
yb=j;
}
}
}
}
} void gch(char& target){
do{
target=getchar();
}while(target!='.'&&target!='X'&&target!='L');
}
Backup

[Codeup 25481] swan的更多相关文章
- 暑假集训D13总结
考试 又炸掉了= = 本来看着题就一脸茫然,默默的打暴力骗分,然后就交了卷= = 重要的是,在本机跑的毫无障碍的T3程序竟然在评测机CE啊喂,35分就没了啊喂(这可是比我现在分还高= =) 内心几近崩 ...
- [Codeup 25482]选美
[Codeup 25482 ]选美 题目 一年一度的星哥选美又拉开了帷幕 N个人报名参加选拔,每个人都有着各自的相貌参数和身材参数(不大于 10000 的正整数).你的任务是尽可能让更多人被星哥选中, ...
- 开发 .swan 文件
这部分是每个智能小程序页面的展现模板,类似于 Web 开发中的 HTML ,SWAN 模板中使用的标签均为 SWAN 组件规定的标签. <view s-for="item in ite ...
- swan.after
解释: swan.after可以拦截所有当前运行小程序对于API的调用,默认传入function时,只在API函数调用的返回阶段拦截.如果传入Object,则可以选择拦截的阶段(例如: 返回阶段.回调 ...
- 阿里云代码管理平台 Teambition Codeup(行云)亮相,为企业代码安全护航
2019杭州云栖大会企业协作与研发效能专场,企业协同平台Teambition负责人齐俊元正式发布阿里云自研的代码管理平台Teambition Codeup(行云),Codeup是一款企业级代码管理产品 ...
- 算法笔记刷题1(codeup 1934)
准备6月份的拼题甲级中(本来现在这两天就考试了,但是因为疫情的原因延期了) 刚刚开始按算法笔记刷题,今天是探索codeup的第一天. 一开始并没有把多点测试当回事,直到一错再错,心态爆炸... 附上我 ...
- 百度小程序中swan.setPageInfo的用法
现在百度智能小程序是百度最新的流量入口,现在很多做SEO优化.小程序开发的企业为了获取更多的流量不得不开发了,很多的技术人员不了解百度小程序的标题和关键词.描述等信息不知道在哪里设置. 以下是小编给你 ...
- 如何从阿里云Code升级至云效Codeup
如果你还在使用阿里云Code,不防看看如何从阿里云Code升级至云效Codeup,云效代码管理Codeup是阿里云出品的一款企业级代码管理平台,提供代码托管.代码评审.代码扫描.质量检测等功能,全方位 ...
- codeup模拟赛 进击的二叉查找数
问题 B: 进击的二叉查找树 时间限制: 1 Sec 内存限制: 64 MB 提交: 1017 解决: 379 提交状态 题目描述 给定1~N的两个排列,使用这两个排列分别构建两棵二叉查找树(也就是通 ...
随机推荐
- java class load 类加载
1:what is it jvm把描述类的数据从class字节码文件加载到内存,并对数据进行校验.解析.初始化,最终成为jvm直接使用的数据类型 1.ClassNotFoundExcetpion ...
- $emit子组件传出多个参数,如何在父组件中在接收所有参数的同时添加自定义参数
很多时候用$emit携带参数传出事件,并且又需要在父组件中使用自定义参数时,这时我们就无法接受到子组件传出的参数了. 找到了两种方法可以同时添加自定义参数的方法. 方法一:子组件传出单个参数时 ...
- SSIS教程:创建简单的ETL包 -- 4. 增加错误处理流程(Adding Error Flow Redirection)
为了处理在转换过程中可能发生的错误,MicrosoftIntegration Services 允许根据每个组件和每个列来决定如何处理无法转换的数据. 可以选择忽略某些列中的失败.重定向整个失败的行或 ...
- Windows窗体技术及基础控件
创建winform程序 Visual studio是一套完整的开发工具集 RAD 工具(rapid application development) 创建用户界面时,把控件从工具箱拖放到窗体上,把它们 ...
- ASP.Net 之委托事件
1.首先给一张图让大家了解什么是委托?它的优缺点是什么? 2.通过代码的运用更深入地了解委托事件(窗体应用程序) 1)下面我们先定义一个无参数的委托. //1.0 定义一个自定义的委托,此委托的签名是 ...
- 微信小程序button选中改样式-实现单选/多选
小程序实现多button单选/多选 红色为选中状态 单选 多选 ①wxss /* pages/button-select/button-select.wxss */ .button_container ...
- RDCMan之DPI 和 Screen Resolution设置
Customer要求在以下环境验证几个bug DPI setting Minimum resolution 96 / 100% 1024x768 120 /125% 1280x960 144 / ...
- php之连接mssql(sql server)新手教程
ps:网上搜了很多教程,讲的都很好,就是都有点漏的地方,花了一天时间查缺补漏终于弄好了(;´༎ຶД༎ຶ`),希望我的教程能帮到新手,还有写博客的时候因为不小心按错一个键,导致重写了,博客园这个编辑器真 ...
- MyBatis学习(一)---配置文件,Mapper接口和动态SQL
MyBatis MyBatis官方学习网站 http://www.mybatis.org/mybatis-3/zh/index.html 为什么需要MyBatis? Jdbc操作数据库的不足之处 1. ...
- 原型链中的prototype、__proto__和constructor的关系
先来看一张图,这张图可以说是围绕以下代码完整的描述了各对象之间的关系.接下来我们来看看如何一步步画出这张图. function Foo(){}; var foo = new Foo(); 首先,明确几 ...