社区讨论
50分求调,必关,急需!
P11228[CSP-J 2024] 地图探险参与者 3已保存回复 5
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 5 条
- 当前快照
- 1 份
- 快照标识符
- @mhj34x7z
- 此快照首次捕获于
- 2025/11/03 19:57 4 个月前
- 此快照最后确认于
- 2025/11/03 19:57 4 个月前
CPP
#include<bits/stdc++.h>
using namespace std;
const int N=1e3+5;
char a[N][N];
bool vis[N][N];
int dx[4]={0,1,0,-1};
int dy[4]={1,0,-1,0};
int main(){
int T;
cin>>T;
while(T--){
memset(vis,1,sizeof(vis));
int n,m,k,x,y,d,ans=1;
cin>>n>>m>>k>>x>>y>>d;
for(int i=1;i<=n;i++){
for(int j=1;j<=m;j++){
cin>>a[i][j];
}
}
for(int i=1;i<=k;i++){
int xx=x+dx[d];
int yy=y+dy[d];//ÏÂÒ»²½
if(1<=xx&&xx<=n&&1<=yy&&yy<=m&&a[xx][yy]=='.'){
x=xx;y=yy;
if(vis[x][y]){
ans++;
vis[x][y]=0;
}
}else{
d=(d+1)%4;
}
}
cout<<ans<<endl;
}
return 0;
}
回复
共 5 条回复,欢迎继续交流。
正在加载回复...