LeetCode 面试题 16.03. 交点

文章目录

一、题目

给定两条线段(表示为起点 start = {X1, Y1} 和终点 end = {X2, Y2}),如果它们有交点,请计算其交点,没有交点则返回空值。

要求浮点型误差不超过 10^-6。若有多个交点(线段重叠)则返回 X 值最小的点,X 坐标相同则返回 Y 值最小的点。

示例 1:

输入:

line1 = {0, 0}, {1, 0}

line2 = {1, 1}, {0, -1}
输出: {0.5, 0}

示例 2:

输入:

line1 = {0, 0}, {3, 3}

line2 = {1, 1}, {2, 2}
输出: {1, 1}

示例 3:

输入:

line1 = {0, 0}, {1, 1}

line2 = {1, 0}, {2, 1}
输出: {},两条线段没有交点

提示:

  • 坐标绝对值不会超过 2^7
  • 输入的坐标均是有效的二维坐标

点击此处跳转题目

二、C# 题解

这题写的心累,参考了 LeetCode 官方解法,代码如下:

csharp 复制代码
public class Solution {
    public double[] Intersection(int[] start1, int[] end1, int[] start2, int[] end2) {
        int       xa  = start1[0], xb = end1[0], xc = start2[0], xd = end2[0];
        int       ya  = start1[1], yb = end1[1], yc = start2[1], yd = end2[1];
        double[] ans = { };

        if ((xa - xb) * (yc - yd) != (ya - yb) * (xc - xd)) { // 不平行
            int    r = (xd - xc) * (yb - ya) - (yd - yc) * (xb - xa);
            int    p = (xc - xa) * (yd - yc) - (yc - ya) * (xd - xc);
            int    q = (xa - xc) * (yb - ya) - (ya - yc) * (xb - xa);
            double m = p * -1.0 / r, n = q * 1.0 / r;
            if (0 <= m && m <= 1 && 0 <= n && n <= 1) 
                ans = new[] { xa + (xb - xa) * m, ya + (yb - ya) * m };
            
        }
        else if ((xa - xb) * (yc - ya) == (ya - yb) * (xc - xa)) { // 平行且在一条直线上
            Operation(xa, ya, xc, yc, xd, yd, ref ans);
            Operation(xb, yb, xc, yc, xd, yd, ref ans);
            Operation(xc, yc, xa, ya, xb, yb, ref ans);
            Operation(xd, yd, xa, ya, xb, yb, ref ans);
        }

        return ans;
    }

    private void Operation(int xp, int yp, int xa, int ya, int xb, int yb, ref double[] ans) {
        if (xp == xa && InLine(yp, ya, yb)) Update(xp, yp, ref ans);
        else if (xp != xa && InLine(xp, xa, xb)) Update(xp, yp, ref ans);
    }

    private bool InLine(int p, int a, int b) {
        return a <= p && p <= b || b <= p && p <= a;
    }

    private void Update(int x, int y, ref double[] ans) {
        if (ans.Length == 0) ans = new double[] { x, y };
        else if (Math.Abs(x - ans[0]) < 1e-6) ans[1] = y < ans[1] ? y : ans[1];
        else if (x < ans[0]) {
            ans[0] = x;
            ans[1] = y;
        }
    }
}
  • 时间:124 ms,击败 66.67% 使用 C# 的用户
  • 内存:41.04 MB,击败 100.00% 使用 C# 的用户
相关推荐
JingHongB6 分钟前
代码随想录算法训练营Day55 | 图论理论基础、深度优先搜索理论基础、卡玛网 98.所有可达路径、797. 所有可能的路径、广度优先搜索理论基础
算法·深度优先·图论
weixin_4327022610 分钟前
代码随想录算法训练营第五十五天|图论理论基础
数据结构·python·算法·深度优先·图论
小冉在学习12 分钟前
day52 图论章节刷题Part04(110.字符串接龙、105.有向图的完全可达性、106.岛屿的周长 )
算法·深度优先·图论
Repeat71513 分钟前
图论基础--孤岛系列
算法·深度优先·广度优先·图论基础
小冉在学习15 分钟前
day53 图论章节刷题Part05(并查集理论基础、寻找存在的路径)
java·算法·图论
武子康27 分钟前
大数据-212 数据挖掘 机器学习理论 - 无监督学习算法 KMeans 基本原理 簇内误差平方和
大数据·人工智能·学习·算法·机器学习·数据挖掘
IT技术分享社区1 小时前
C#实战:使用腾讯云识别服务轻松提取火车票信息
开发语言·c#·云计算·腾讯云·共识算法
passer__jw7671 小时前
【LeetCode】【算法】283. 移动零
数据结构·算法·leetcode
Ocean☾1 小时前
前端基础-html-注册界面
前端·算法·html
顶呱呱程序1 小时前
2-143 基于matlab-GUI的脉冲响应不变法实现音频滤波功能
算法·matlab·音视频·matlab-gui·音频滤波·脉冲响应不变法