AtCoder Beginner Contest 184 E - Third Avenue (BFS)
2024-08-31 22:48:58
- 题意:给你一张图,\(S\)表示起点,\(G\)表示终点,\(.\)表示可以走,#表示不能走,小写字母可以传送到任意一个相同的字母的位置,问从\(S\)走到\(G\)的最小步数.
- 题解:假如不考虑字母的话,就是一个经典的bfs,当我们走到字母时,将其它相同字母的位置入队,之后就不会再将它们入队了,因为之后走到这个字母的步数一定大于第一次传送的步数,所以我们可以先记录每个字母的位置,然后跑个bfs即可.
- 代码:
struct misaka{
int x,y;
int cnt;
}e[N];
int n,m;
char s[2100][2100];
bool st[2100][2100];
vector<PII> v[30];
PII stt;
const int dx[4]={0,0,-1,1},dy[4]={-1,1,0,0};
bool c[30];
void bfs(){
queue<misaka> q;
q.push({stt.fi,stt.se,0});
bool flag=false;
while(!q.empty()){
auto tmp=q.front();
q.pop();
int x=tmp.x;
int y=tmp.y;
int cnt=tmp.cnt;
if(st[x][y]) continue;
st[x][y]=true;
if(s[x][y]=='G'){
flag=true;
cout<<cnt;
break;
}
if(s[x][y]>='a' && s[x][y]<='z' && !c[s[x][y]-'a']){
for(auto w : v[s[x][y]-'a']){
q.push({w.fi,w.se,cnt+1});
c[s[x][y]-'a']=true;
}
}
rep(i,0,3){
int tx=x+dx[i];
int ty=y+dy[i];
if(tx<1 || tx>n || ty<1 || ty>m) continue;
if(tx>=1 && tx<=n && ty>=1 && ty<=m && s[tx][ty]!='#' && !st[tx][ty] && !c[s[tx][ty]-'a']){
q.push({tx,ty,cnt+1});
}
}
}
if(!flag) cout<<-1;
}
int main() {
ios::sync_with_stdio(false);cin.tie(0);cout.tie(0);
cin>>n>>m;
rep(i,1,n){
rep(j,1,m){
cin>>s[i][j];
if(s[i][j]=='S') stt={i,j};
if(s[i][j]>='a' && s[i][j]<='z') v[s[i][j]-'a'].pb({i,j});
}
}
bfs();
return 0;
}
最新文章
- [bigdata] kafka基本命令 -- 迁移topic partition到指定的broker
- ubuntu E: Could not get lock /var/lib/dpkg/lock - open
- 如何用 React Native 创建一个iOS APP?
- B - 楼下水题(扩展欧几里德)
- Underscore.js 的模板功能介绍与应用
- Hive 报错:java.lang.RuntimeException: Unable to instantiate org.apache.hadoop.hive.metastore.HiveMetaStoreClient
- ejabberd编译更新脚本
- C++中重载、覆盖与隐藏的区别(转)
- 理解滑动平均(exponential moving average)
- ECMA Script 6_行为重定义 Proxy
- windows中,VS2017下,在Cmake中添加OpenCV依赖
- SpringMVC之使用ResponseEntity,java接口返回HttpStatus
- Jekins在Tomcat上的安装和配置
- golang文件相对路径问题
- 深度分析:Android中Mms设置页面更改短信中心号码流程
- 牛客多校第五场 J:Plan
- 我的开源项目——Jerry
- 如何在网上隐藏自己的IP地址(转)
- [JS] selector 背景选择器
- 怎么在Linux上抓包分析