思路:
这道题比较简单,只要搞清楚x,y的坐标是从哪里开始的,并且明白蚂蚁在不同格子内的朝向带来的x,y的变化,就容易许多,我的应该并不是最优解。
#include<iostream>
using namespace std;
int main(){
int n,m;
cin>>m>>n;
int x,y,k,x_,y_;
char S;
int a[m][n];
for(int i=0;i<m;i++)
for(int j=0;j<n;j++)
cin>>a[i][j];
cin>>x>>y>>S>>k;
for(int i=0;i<k;i++){
if(a[x][y]==0){//对白格子分析
x_=x;
y_=y; //定义x_,y_存放原始位置以便于修改颜色值
if(S=='U'){
S='L';
y--;
}else if(S=='L'){
S='D';
x++;
}else if(S=='D'){
S='R';
y++;
}else{
S='U';
x--;
}
a[x_][y_]=1;
}
else if(a[x][y]==1){//对黑格子分析
x_=x;
y_=y;
if(S=='U'){
S='R';
y++;
}else if(S=='L'){
S='U';
x--;
}else if(S=='D'){
S='L';
y--;
}else{
S='D';
x++;
}
a[x_][y_]=0;
}
}
cout<<x<<" "<<y<<endl;
return 0;
}
0.0分
0 人评分
九宫重排 (C++代码)浏览:1336 |
上车人数 (C语言代码)浏览:781 |
C语言程序设计教程(第三版)课后习题4.9 (C语言代码)浏览:377 |
WU-蓝桥杯算法提高VIP-勾股数 (C++代码)浏览:1607 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:678 |
简单的a+b (C语言代码)浏览:546 |
2003年秋浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:683 |
演讲大赛评分 (C语言代码)浏览:1641 |
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:588 |
2006年春浙江省计算机等级考试二级C 编程题(1) (C语言代码)浏览:669 |