#include<stdio.h>
#define MAX 100

char dir[5] = {'U', 'R', 'D', 'L'};
int color[MAX][MAX];
int m, n;
int x, y, dir_tmp, step; 

int getNumOfDir(char d)
{              	
	if (d == 'U') return 0;
	if (d == 'R') return 1;
	if (d == 'D') return 2;
	if (d == 'L') return 3; 
 } 
 
 void Move()//前进 
 {
 	if(dir_tmp == 'U')
 	{	
 		if(x != 0)
 		{
 			x -= 1; 
// 			printf("%c x = %d, y = %d\n",dir_tmp, x, y);//debug
 			return;
		 }
	 }
	 
	 if(dir_tmp == 'R')
	 {
	 	if(y != n-1) 
	 	{
	 		y += 1;
//	 		printf("%c x = %d, y = %d\n",dir_tmp, x, y);//debug
	 		return;
		 }
	 }
	 
	 if(dir_tmp == 'D')
	 {
	 	if (x != m-1)
	 	{
	 		x += 1;
//	 		printf("%c x = %d, y = %d\n",dir_tmp, x, y);//debug
	 		return ;
		 }
	 }
	 
	 if(dir_tmp == 'L')
	 {
	 	if(y != 0)
	 	{
	 		y -= 1;
//	 		printf("%c x = %d, y = %d\n",dir_tmp, x, y);//debug
	 		return;
		 }
	 }
 }
 

int main()
{

	int i, j;
	int getN;
	
	scanf("%d%d", &m, &n);
	for (i = 0; i < m; ++i)
		for (j = 0; j < n; ++j)
		{
			scanf("%d", &color[i][j]);
		}
	scanf("%d %d %c %d", &x, &y, &dir_tmp, &step);
//	printf("%d %d %c %d\n", x, y, dir_tmp, step);//debug

	while(step--)
	{
		if(color[x][y] == 1)
		{
			color[x][y] = 0;
			getN = getNumOfDir(dir_tmp) + 5;
			dir_tmp = dir[getN%4];
//			printf("dir_tmp = %c\ngetN = %d\n", dir_tmp, getN%4);//debug
			Move();
		}
		else
		{
			color[x][y] = 1;
			getN = getNumOfDir(dir_tmp) + 3;
			dir_tmp = dir[getN%4]; 
//			printf("dir_tmp = %c\ngetN = %d\n", dir_tmp, getN%4);//debug
			Move();
		}
	}
	printf("%d %d\n", x, y);
	
	return 0;
 }
点赞(0)
 

0.0分

0 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论