news 2026/4/18 8:01:17

经典算法题详解之游乐园的迷宫(三)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
经典算法题详解之游乐园的迷宫(三)

解决方案

平面上有 个点,找到一条访问 个点的路径,使得路径的转角满足给定的转角序列。

题解

我们保持一个理想的状态:转向时,剩余的点都位于要求方向的一侧(即剩余点都符合当前这次的转向要求)。那么当前这次转向选择什么点,可以使下一次转向依旧满足这个理想的状态,从而可以不断的递归找下去。

若下一次转向的要求方向是 L (R),则这次转向的点中选择相对方向最右(最左)的点即可。

C++ 实现

class Solution { private: pair<int, int> Sub(pair<int, int> a, pair<int, int> b) { // 求点 a 到点 b 的向量 return make_pair(a.first - b.first, a.second - b.second); } int Cross(pair<int, int> a, pair<int, int> b) { // 求向量 a 到向量 b 的向量叉积 return a.first * b.second - a.second * b.first; } public: vector<int> visitOrder(vector< vector<int> >& points, string dir) { int n = points.size(); vector<bool> used(n, false); // 记录点的遍历情况, False未遍历 / True已遍历 vector< pair<int, int> > point; vector<int> order; // 记录返回结果 for (int i=0; i<n; ++i) { point.push_back( make_pair(points[i][0], points[i][1]) ); } // 查找最左的点作为 起始点 int start = 0; for (int i=1; i<n; ++i) { if (point[i] < point[start]) { start = i; } } used[start] = true; order.push_back(start); for (int i=0; i<dir.size(); ++i) { int next = -1; if (dir[i] == 'L') { // 转向方向为 L,选择相对方向最右的点 for (int j=0; j<n; ++j) { if (!used[j]) { if (next == -1 || Cross(Sub(point[next], point[start]), Sub(point[j], point[start])) < 0) { next = j; } } } } else if (dir[i] == 'R') { // 转向方向为 R,选择相对方向最左的点 for (int j=0; j<n; ++j) { if (!used[j]) { if (next == -1 || Cross(Sub(point[next], point[start]), Sub(point[j], point[start])) > 0) { next = j; } } } } // 返回结果加入选择的点,更新下一次转向的起点 used[next] = true; order.push_back(next); start = next; } // 添加最后一个剩余点 for (int i=0; i<n; ++i) { if (used[i] == false) { order.push_back(i); } } return order; } };
版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 8:50:02

day 27

浙大疏锦行

作者头像 李华
网站建设 2026/4/18 7:57:46

昆明炸洋芋:街边小摊上的香辣腐乳酱与爽脆口感

在昆明乃至整个云南&#xff0c;有一种小吃可以跨越阶层与场合&#xff0c;成为全民共同的味觉记忆&#xff0c;那就是炸洋芋。它看似简单&#xff0c;却在油温、火候与蘸料的细微差别中&#xff0c;衍生出千变万化的风味宇宙&#xff0c;其中最令人魂牵梦萦的&#xff0c;莫过…

作者头像 李华
网站建设 2026/4/18 7:42:20

MUVERA算法详解:如何让大模型检索速度提升10倍

MUVERA算法创新性地将多向量检索问题转化为单向量最大内积搜索&#xff0c;通过固定维度编码(FDE)技术大幅降低内存占用(节省近80%)和提升检索效率(HNSW图节点缩减至1%)。该算法通过空间划分、降维、重复增强和最终投影四步实现&#xff0c;在保持较高召回率的同时&#xff0c;…

作者头像 李华
网站建设 2026/4/17 19:56:34

档案信创先行:眉山市档案馆馆藏系统上线,国产数据库筑牢安全底座

在国家全面推进信息技术应用创新与数字中国建设的背景下&#xff0c;档案作为党和国家的重要信息资产&#xff0c;其管理系统的安全可控已上升为战略要求。2025年2月&#xff0c;四川省眉山市档案馆在全新建设馆藏档案管理系统过程中&#xff0c;坚决贯彻“源头自主可控”原则&…

作者头像 李华
网站建设 2026/4/16 10:39:32

浊度传感器的核心技术优势与应用价值

在当今的工业与环保领域&#xff0c;对水质参数的实时、精准监测需求日益增长。浊度&#xff0c;作为衡量水体中悬浮颗粒物含量的关键指标&#xff0c;其监测的准确性直接关系到工艺控制、合规达标与资源安全。FST100-ZD102智慧型浊度传感器集多项前沿技术于一身&#xff0c;提…

作者头像 李华