解题思路:
定义俩个方向数组

int dx[] = {0, 1, 0, -1};

 int dy[] = {1, 0, -1, 0};



注意事项:

主要是定义方向的变量黑色方块(direction + 3) % 4,即顺时针转三次,如初始时刻direction=0,(direction + 3) % 4时等于3,dx[3]=-1,dy[3]=0向上移动;同理如果是白色方块顺时针一次direction = (direction + 1) % 4;然后通过k来控制循环次数。

****注意输入时到字符串应该要有一个空格来输入scanf("%d%d %c%d", &x, &y, &s, &k);

 参考代码:

#include <stdio.h>

int main() {

    int i, j, m, n, k, x, y;

    char s;

    scanf("%d%d", &m, &n);

    int arr[m][n];

    for (i = 0; i < m; i++) {

        for (j = 0; j < n; j++) {

            scanf("%d", &arr[i][j]);

        }

    }

    scanf("%d%d %c%d", &x, &y, &s, &k); 

    int direction = 0; 

    if (s == 'D') direction = 1; 

    else if (s == 'L') direction = 2; 

    else if (s == 'U') direction = 3; 

    int dx[] = {0, 1, 0, -1};

    int dy[] = {1, 0, -1, 0};

    while (k > 0) {

        if (x < 0 || x >= m || y < 0 || y >= n) {

            break; 

        }

        if (arr[x][y] == 0) { 

            direction = (direction + 3) % 4; 

            arr[x][y] = 1; 

        } else {

            direction = (direction + 1) % 4; 

            arr[x][y] = 0;  

        }

        x += dx[direction];

        y += dy[direction];

        k--;  

    }

    printf("%d %d\n", x, y);

    return 0;

}


点赞(0)
 

0.0分

1 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论