【LeetCode 算法】Walking Robot Simulation 模拟行走机器人 - 二分

这篇具有很好参考价值的文章主要介绍了【LeetCode 算法】Walking Robot Simulation 模拟行走机器人 - 二分。希望对大家有所帮助。如果存在错误或未考虑完全的地方,请大家不吝赐教,您也可以点击"举报违法"按钮提交疑问。

Walking Robot Simulation 模拟行走机器人

问题描述:

机器人在一个无限大小的 XY 网格平面上行走,从点 (0, 0) 处开始出发,面向北方。该机器人可以接收以下三种类型的命令 commands :

-2 :向左转 90 度
-1 :向右转 90 度
1 < = x < = 9 1 <= x <= 9 1<=x<=9 :向前移动 x 个单位长度
在网格上有一些格子被视为障碍物 obstacles 。第 i 个障碍物位于网格点 o b s t a c l e s [ i ] = ( x i , y i ) obstacles[i] = (x_i, y_i) obstacles[i]=(xi,yi)

机器人无法走到障碍物上,它将会停留在障碍物的前一个网格方块上,但仍然可以继续尝试进行该路线的其余部分。

返回从原点到机器人所有经过的路径点(坐标为整数)的最大欧式距离的平方。(即,如果距离为 5 ,则返回 25 )

1 < = c o m m a n d s . l e n g t h < = 1 0 4 c o m m a n d s [ i ] i s o n e o f t h e v a l u e s i n t h e l i s t [ − 2 , − 1 , 1 , 2 , 3 , 4 , 5 , 6 , 7 , 8 , 9 ] 0 < = o b s t a c l e s . l e n g t h < = 1 0 4 − 3 ∗ 1 0 4 < = x i , y i < = 3 ∗ 1 0 4 答案保证小于 2 31 1 <= commands.length <= 10^4\\ commands[i] is one of the values in the list [-2,-1,1,2,3,4,5,6,7,8,9]\\ 0 <= obstacles.length <= 10^4\\ -3 * 10^4 <= xi, yi <= 3 * 10^4\\ 答案保证小于 2^{31} 1<=commands.length<=104commands[i]isoneofthevaluesinthelist[2,1,1,2,3,4,5,6,7,8,9]0<=obstacles.length<=1043104<=xi,yi<=3104答案保证小于231

分析

模拟问题属于看上去很简单,但是做起来处处是坑。

这个问题中,可以移动的范围可以看做是一个二维直角坐标系。起始点是原点[0,0],这个移动范围是不受边界限制的,它不同于一般的矩阵,有行列大小限制。

加速可以使用二分

当然也可以使用二分,在移动的过程中使用二分来快速判断是否会遇到obstacle,整体时间复杂度 O ( N + M ∗ C l o g X ) O(N+M*ClogX) O(N+MClogX)

代码

二分

class Solution {
    int INF = Integer.MAX_VALUE;
    public int robotSim(int[] commands, int[][] obstacles) {
        Map<Integer,List<Integer>> mapx = new HashMap();
        Map<Integer,List<Integer>> mapy = new HashMap();
        for(int [] obs :obstacles){
            int x = obs[0],y = obs[1];
            List<Integer> xlist = mapx.getOrDefault(x,new ArrayList());
            List<Integer> ylist = mapy.getOrDefault(y,new ArrayList()); 
            xlist.add(y);
            ylist.add(x);
            mapx.put(x,xlist);
            mapy.put(y,ylist);        
        }
        for(int k : mapx.keySet()){
            List<Integer> list = mapx.get(k);
            Collections.sort(list);
            mapx.put(k,list);
        }
        for(int k : mapy.keySet()){
            List<Integer> list = mapy.get(k);
            Collections.sort(list);
            mapy.put(k,list);
        }
        int d = 0; // direction
        int[][] dir = new int[][]{{0,1},{1,0},{0,-1},{-1,0}};// N,E,S,W

        int n = commands.length;
        int idx = 0,cx = 0,cy = 0,ans=0;
        while(idx<n){
            int c = commands[idx];
            if(c<0){ 
                if(c==-2) d = (d+3)%4;
                else d = (d+1)%4; 
            }
            else{                
                int nx = cx+ dir[d][0]*c;
                int ny = cy+ dir[d][1]*c;
                int obs = INF;
                if(d%2==0){
                    // N S 
                    if(d==0){
                        if(mapx.containsKey(cx)){
                            obs = find1(mapx.get(cx),cy);
                        }
                        if(obs!=INF&&obs<=ny){
                            ny = obs-1;
                        }
                    }
                    else{
                        if(mapx.containsKey(cx)){ 
                            obs = find2(mapx.get(cx),cy); 
                        }
                        if(obs!=INF&&obs>=ny){
                            ny = obs+1;
                        }
                    }  
                }
                else{
                    // E W
                    if(d==1){
                        if(mapy.containsKey(cy)){
                            obs = find1(mapy.get(cy),cx);
                        }
                        if(obs!=INF&&obs<=nx){
                            nx = obs-1;
                        }
                    }
                    else{
                        if(mapy.containsKey(cy)){

                            obs = find2(mapy.get(cy),cx);
                        }
                        if(obs!=INF&&obs>=nx){
                            nx = obs+1;
                        }
                    } 
                } 
                int res = nx*nx + ny*ny;
                ans = Math.max(ans,res); 
                cx = nx; cy = ny;
 
            }
            idx++; 
        } 
        return ans;    
    }
    // find first > tar
    public int find1(List<Integer> list,int tar){
        if(list.size()==0
        ||list.get(list.size()-1)<tar) return INF;
        if(list.get(0)>tar) return list.get(0);
        int n = list.size();
        // 0~n-1
        int l = 0,r = n-1,mid = 0;
        while(l<r){
            mid = l+(r-l)/2;
            if(list.get(mid)>tar) r = mid;
            else l = mid+1;
        }
        return list.get(l)>tar?list.get(l):INF;
    }
    // find first < tar
    public int find2(List<Integer> list,int tar){
        if(list.size()==0
        ||list.get(0)>tar) return INF;
        int n = list.size();
        if(list.get(n-1)<tar) return list.get(n-1);
        // 0~n-1
        int l = 0,r = n-1,mid = 0;
        while(l<r){
            mid = l+(r-l+1)/2;
            if(list.get(mid)>=tar) r = mid-1;
            else l = mid;
        } 
        return list.get(l)<tar?list.get(l):INF;
    }
}

时间复杂度 O ( N + M ∗ C l o g X ) O(N+M*ClogX) O(N+MClogX)

空间复杂度 O ( M ) O(M) O(M)

Tag

Array

Simulation文章来源地址https://www.toymoban.com/news/detail-677138.html

到了这里,关于【LeetCode 算法】Walking Robot Simulation 模拟行走机器人 - 二分的文章就介绍完了。如果您还想了解更多内容,请在右上角搜索TOY模板网以前的文章或继续浏览下面的相关文章,希望大家以后多多支持TOY模板网!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处: 如若内容造成侵权/违法违规/事实不符,请点击违法举报进行投诉反馈,一经查实,立即删除!

领支付宝红包赞助服务器费用

相关文章

  • leetcode刷题(字符串相加、包含每个查询的最小区间、模拟行走机器人、环形子数组的最大和、满足不等式的最大值、四数之和、树中距离之和)

    leetcode刷题(字符串相加、包含每个查询的最小区间、模拟行走机器人、环形子数组的最大和、满足不等式的最大值、四数之和、树中距离之和)

    目录 1、字符串相加 2、包含每个查询的最小区间 3、模拟行走机器人 4、环形子数组的最大和 5、满足不等式的最大值 6、四数之和 7、 树中距离之和

    2024年02月10日
    浏览(8)
  • 1041.困于环中的机器人 && 874.模拟行走的机器人 && 模拟行走的机器人 2 (三道机器人的模拟题)

    对于直接行走类的题,我们都可以用 int[][] dirs = new int[][]{{0,1}, {-1,0}, {0,-1}, {1,0}}; 来表示向 北 西 南 东 走一步 可以 int x = 0, y = 0, d = 0 xy 表示坐标,d表示方向,要和上面表示的方向对应 由于是对应的 d = 0 表示北 d = 1 表示西 d = 2 表示南 d = 3 表示东 即逆时针一圈 左转: d =

    2024年02月16日
    浏览(16)
  • 874. 模拟行走机器人 模拟+哈希存储

    题目链接力扣 机器人在一个无限大小的 XY 网格平面上行走,从点  (0, 0)  处开始出发,面向北方。该机器人可以接收以下三种类型的命令  commands  : -2  :向左转  90  度 -1  :向右转  90  度 1 = x = 9  :向前移动  x  个单位长度 在网格上有一些格子被视为障碍物  obst

    2024年02月11日
    浏览(10)
  • 874. 模拟行走机器人

    874. 模拟行走机器人 机器人在一个无限大小的 XY 网格平面上行走,从点  (0, 0)  处开始出发,面向北方。该机器人可以接收以下三种类型的命令  commands  : -2  :向左转  90  度 -1  :向右转  90  度 1 = x = 9  :向前移动  x  个单位长度 在网格上有一些格子被视为障碍物

    2024年02月16日
    浏览(9)
  • 【每日一题】874. 模拟行走机器人

    机器人在一个无限大小的 XY 网格平面上行走,从点 (0, 0) 处开始出发,面向北方。该机器人可以接收以下三种类型的命令 commands : -2 :向左转 90 度 -1 :向右转 90 度 1 = x = 9 :向前移动 x 个单位长度 在网格上有一些格子被视为障碍物 obstacles 。第 i 个障碍物位于网格点 obst

    2024年02月16日
    浏览(8)
  • 每日一题(set集合)-874. 模拟行走机器人

    874. 模拟行走机器人 初始方向朝y轴正方向,遇到指令command == -1 则向右转, 若为 -2 则向左转 定义方向[-1,0]、[0,1]、[1,0]、[0,-1] 分别为朝x轴负方向, y轴正方向, x轴正方向,y轴负方向 初始方向为[0,1], 若向右转 则方向变为[-1,0]、若向左转方向变为[1,0]。 若向右转则不断 向右

    2024年02月13日
    浏览(8)
  • 暑期代码每日一练Day3:874. 模拟行走机器人

    暑期代码每日一练Day3:874. 模拟行走机器人

    题目 874. 模拟行走机器人 分析 这道题就是个简单的模拟 主要有两点考察点: 对 方向数组 的运用 方向数组存储的是各个方向的单位向量,也即: 方向 X Y 向北 0 1 向东 1 0 向南 0 -1 向西 -1 0 存储在数组中,则是方向数组: 我们很容易发现: 我们可以使用一个变量 j 来指示当

    2024年02月16日
    浏览(11)
  • 第二章:Introduction to Web Hacking —— 00 Walking An Application 行走应用程序

    第二章:Introduction to Web Hacking —— 00 Walking An Application 行走应用程序

    仅使用浏览器开发人员工具手动检查 Web 应用程序是否存在安全问题。只需使用浏览器即可进行黑客攻击,无需任何工具或脚本。 在这个房间中,您将学习如何仅使用浏览器中的内置工具手动检查 Web 应用程序的安全问题。通常,自动化安全工具和脚本会错过许多潜在的漏洞

    2024年02月21日
    浏览(7)
  • 机器人控制算法——TEB算法—Obstacle Avoidance and Robot Footprint Model(避障与机器人足迹模型)

    机器人控制算法——TEB算法—Obstacle Avoidance and Robot Footprint Model(避障与机器人足迹模型)

    1.1处罚条款 避障是作为整体轨迹优化的一部分来实现的。显然,优化涉及到找到指定成本函数(目标函数)的最小成本解(轨迹)。简单地说:如果一个计划的(未来)姿势违反了与障碍物的期望分离,那么成本函数的成本必须增加。理想情况下,在这些情况下,成本函数值

    2024年02月06日
    浏览(9)
  • (二)基于wpr_simulation 的Ros机器人运动控制,gazebo仿真

    (二)基于wpr_simulation 的Ros机器人运动控制,gazebo仿真

    一、创建工作空间          二、下载wpr_simulation源码 git clone https://github.com/6-robot/wpr_simulation.git 三、编译 ~/catkin_make  目录下catkin_make source devel/setup.bash 四、运行 roslaunch wpr_simulation wpb_simple.launch 启动另一个终端,执行: rosrun rqt_robot_steering rqt_robot_steering 鼠标改变速度和角

    2024年01月20日
    浏览(44)

觉得文章有用就打赏一下文章作者

支付宝扫一扫打赏

博客赞助

微信扫一扫打赏

请作者喝杯咖啡吧~博客赞助

支付宝扫一扫领取红包,优惠每天领

二维码1

领取红包

二维码2

领红包