网站开发交流群,站长素材音效下载,wordpress如何添加自定义链接,网站开发的资料设备1. 题目
给你一个字符串 path#xff0c;其中 path[i] 的值可以是 ‘N’、‘S’、‘E’ 或者 ‘W’#xff0c;分别表示向北、向南、向东、向西移动一个单位。
机器人从二维平面上的原点 (0, 0) 处开始出发#xff0c;按 path 所指示的路径行走。
如果路径在任何位置上出…1. 题目
给你一个字符串 path其中 path[i] 的值可以是 ‘N’、‘S’、‘E’ 或者 ‘W’分别表示向北、向南、向东、向西移动一个单位。
机器人从二维平面上的原点 (0, 0) 处开始出发按 path 所指示的路径行走。
如果路径在任何位置上出现相交的情况也就是走到之前已经走过的位置请返回 True 否则返回 False 。
示例 1
输入path NES
输出false
解释该路径没有在任何位置相交。示例 2
输入path NESWW
输出true
解释该路径经过原点两次。提示
1 path.length 10^4
path 仅由 {N, S, E, W} 中的字符组成来源力扣LeetCode 链接https://leetcode-cn.com/problems/path-crossing 著作权归领扣网络所有。商业转载请联系官方授权非商业转载请注明出处。 2. 解题
set 查重即可
class Solution {//C
public:bool isPathCrossing(string path) {setpairint,int s;s.insert({0,0});int x 0, y 0;for(int i 0; i path.size(); i){if(path[i] N)y;else if(path[i] S)y--;else if(path[i] E)x;elsex--;if(s.find({x,y}) ! s.end())return true;elses.insert({x,y});}return false;}
};4 ms 6.9 MB
class Solution:#py3def isPathCrossing(self, path: str) - bool:s set()s.add(tuple([0,0]))x 0y 0for i in range(len(path)):if path[i] N:y 1elif path[i] S:y - 1elif path[i] E:x 1else:x - 1if tuple([x,y]) in s:return True;else:s.add(tuple([x,y]))return False44 ms 13.7 MB