zoukankan      html  css  js  c++  java
  • 30 Day Challenge Day 21 | Leetcode 1197. Minimum Knight Moves

    class Solution {
    public:
        int minKnightMoves(int x, int y) {
            int steps = 0;
            
            unordered_set<string> s;
            
            queue<pair<int, int>> q;
            q.push({0, 0});
            
            s.insert(to_string(0) + '-' + to_string(0));
            
            int dirs[8][2] = {{-2, 1},
                              {-2, -1},
                              {2, 1},
                              {2, -1},
                              {-1, 2},
                              {-1, -2},
                              {1, 2},
                              {1, -2}
                             };
            
            while(!q.empty()) {
                int sz = q.size();
                for(int i = 0; i < sz; i++) {
                    auto t = q.front();
                    q.pop();
                    
                    if(t.first == x && t.second == y) return steps;
                    
                    for(int k = 0; k < 8; k++) {
                        int next_x = t.first + dirs[k][0];
                        int next_y = t.second + dirs[k][1];
                        if(!s.count(to_string(next_x) + '-' + to_string(next_y))) {
                            q.push({next_x, next_y});
                            s.insert(to_string(next_x) + '-' + to_string(next_y));
                        }
                    }
                }
                steps++;
            }
            
            return -1;
        }
    };
    

    改进:

    利用对称性:四个象限的坐标是具有无符号对称性的。那么不考虑象限,或者把所有坐标转换到第一象限,是不影响结果的。

    class Solution {
    public:
        int minKnightMoves(int x, int y) {
            // reduce the search space
            x = abs(x);
            y = abs(y);
            
            int steps = 0;
            
            unordered_set<string> s;
            
            queue<pair<int, int>> q;
            q.push({0, 0});
            
            s.insert(to_string(0) + '-' + to_string(0));
            
            int dirs[8][2] = {{-2, 1},
                              {-2, -1},
                              {2, 1},
                              {2, -1},
                              {-1, 2},
                              {-1, -2},
                              {1, 2},
                              {1, -2}
                             };
            
            while(!q.empty()) {
                int sz = q.size();
                for(int i = 0; i < sz; i++) {
                    auto t = q.front();
                    q.pop();
                    
                    if(t.first == x && t.second == y) return steps;
                    
                    for(int k = 0; k < 8; k++) {
                        int next_x = t.first + dirs[k][0];
                        int next_y = t.second + dirs[k][1];
                        if(!s.count(to_string(next_x) + '-' + to_string(next_y))
                          && next_x >= -2 && next_y >= -2 && next_x < x+2 && next_y < y+2) { // reduce the search space
                            q.push({next_x, next_y});
                            s.insert(to_string(next_x) + '-' + to_string(next_y));
                        }
                    }
                }
                steps++;
            }
            
            return -1;
        }
    };
    
  • 相关阅读:
    scroll-behavior 让滚动更顺滑
    CSS3实现类似装订(缝纫)效果
    hadoop伪分布安装
    开始hadoop
    Boostrap 模态框 水平垂直居中问题
    ASP.NET MVC 下 引用阿里巴巴和IconFont字体路径404问题
    ajax 初始化请求前携带参数
    边框圆角方法
    DIV 清除样式浮动万能代码
    ASP.NET MVC 增强Convert用法+【分页2】
  • 原文地址:https://www.cnblogs.com/casperwin/p/13783571.html
Copyright © 2011-2022 走看看