解题思路:

注意事项:

参考代码:

T = int(input())

for _ in range(T):
    n = int(input())
    matrix = [list(input().split()[0]) for _ in range(n)]
    m = int(input())
    q = [list(input().split()[0]) for _ in range(m)]
    #   先通过遍历得到 起点和终点
    x1 = x2 = y1 = y2 = 0
    for i in range(n):
        for j in range(n):
            if matrix[i][j] == 'S':
                x1 = i
                y1 = j
            if matrix[i][j] == 'T':
                x2 = i
                y2 = j


    #   然后针对每一次的查询,输出结果
    for i in range(m):
        l = q[i]
        x, y = x1, y1
        for ch in l:
            if ch == 'L':
                y -= 1
            elif ch == 'R':
                y += 1
            elif ch == 'U':
                x -= 1
            else:
                x += 1
            #   判断结果是否出界,或者是到达终点,或者是遇到障碍物
            if x < 0 or x >= n or y < 0 or y >= n:
                print("I am out!")
                break
            elif x == x2 and y == y2:
                print("I get there!")
                break
            elif matrix[x][y] == '#':
                print("I am dizzy!")
                break
        else:
            print("I have no idea!")


点赞(0)
 

0.0分

0 人评分

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

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

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

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

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

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

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

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

评论列表 共有 0 条评论

暂无评论