【C#】计算两条直线的交点坐标

问题描述

计算两条直线的交点坐标,可以理解为给定坐标P1、P2、P3、P4,形成两条线,返回这两条直线的交点坐标?

注意区分:这两条线是否垂直、是否平行。

 

代码实现

斜率解释

斜率是数学中的一个概念,特别是在解析几何和平面直角坐标系中,用来描述一条直线倾斜程度的量。它定义为直线上任意两点之间的垂直变化量(即纵坐标的变化量,通常称为“上升”或“Δy”)与水平变化量(即横坐标的变化量,通常称为“运行”或“Δx”)之比。斜率通常用字母 m 表示。

6af594287d3649baa8746d1254c040a5.png

需要注意的是,对于垂直线,由于水平变化量“Δx” 为零,所以斜率无法定义,因为这会导致分母为零,我们说垂直线的斜率是无穷大或未定义。

斜率的概念在许多数学和物理问题中都有应用,例如在微积分中,导数可以看作是曲线在某一点处的瞬时斜率;在物理学中,斜率可以表示速度、加速度等随时间的变化率。

在实际应用中,斜率也可以帮助我们理解数据的趋势,比如在统计学中,通过计算散点图中数据点的斜率,我们可以了解变量间的关系是正相关还是负相关。

 

方法1:两条线不一定垂直

using System;class Program
{struct Point{public double X;public double Y;public Point(double x, double y){X = x;Y = y;}}static Point FindIntersection(Point p1, Point p2, Point p3, Point p4){double a1 = p2.Y - p1.Y;double b1 = p1.X - p2.X;double c1 = a1 * p1.X + b1 * p1.Y;double a2 = p4.Y - p3.Y;double b2 = p3.X - p4.X;double c2 = a2 * p3.X + b2 * p3.Y;double det = a1 * b2 - a2 * b1;if (det == 0){// 两条直线平行或重合,无交点或有无穷多个交点return new Point(double.NaN, double.NaN);}double x = (b2 * c1 - b1 * c2) / det;double y = (a1 * c2 - a2 * c1) / det;return new Point(x, y);}static void Main(){Point p1 = new Point(1, 1);Point p2 = new Point(3, 3);Point p3 = new Point(1, 3);Point p4 = new Point(3, 1);Point intersection = FindIntersection(p1, p2, p3, p4);if (double.IsNaN(intersection.X) && double.IsNaN(intersection.Y)){Console.WriteLine("两条直线平行或重合,无交点或有无穷多个交点");}else{Console.WriteLine($"交点坐标为 ({intersection.X}, {intersection.Y})");}}
}

例如,如果 P1(1, 1)P2(3, 3) 代表一条直线,P3(1, 3)P4(3, 1) 代表另一条直线,通过上述代码就能计算出它们的交点坐标。如果两条直线平行,如 P1(1, 1)P2(2, 2) 和 P3(1, 2)P4(2, 1),则返回 (NaN, NaN) 表示无交点。

方法2:两条线垂直

using System;class Program
{struct Point{public double X;public double Y;public Point(double x, double y){X = x;Y = y;}}static Point FindPerpendicularIntersection(Point p1, Point p2, Point p3, Point p4){// 计算两条直线的斜率double slope1 = (p2.Y - p1.Y) / (p2.X - p1.X);double slope2 = (p4.Y - p3.Y) / (p4.X - p3.X);// 如果两条直线中有一条斜率不存在(即垂直于 x 轴)if (double.IsInfinity(slope1)){double x = p1.X;double y = slope2 * (x - p3.X) + p3.Y;return new Point(x, y);}else if (double.IsInfinity(slope2)){double x = p3.X;double y = slope1 * (x - p1.X) + p1.Y;return new Point(x, y);}// 两条直线斜率都存在时double perpendicularSlope1 = -1 / slope1;double perpendicularSlope2 = -1 / slope2;// 计算直线的方程double intercept1 = p1.Y - perpendicularSlope1 * p1.X;double intercept2 = p3.Y - perpendicularSlope2 * p3.X;// 计算交点坐标double x = (intercept2 - intercept1) / (perpendicularSlope1 - perpendicularSlope2);double y = perpendicularSlope1 * x + intercept1;return new Point(x, y);}static void Main(){Point p1 = new Point(1, 1);Point p2 = new Point(3, 3);Point p3 = new Point(1, 3);Point p4 = new Point(3, 1);Point intersection = FindPerpendicularIntersection(p1, p2, p3, p4);if (double.IsNaN(intersection.X) && double.IsNaN(intersection.Y)){Console.WriteLine("两条直线平行或重合,无垂直交点或有无穷多个垂直交点");}else{Console.WriteLine($"垂直交点坐标为 ({intersection.X}, {intersection.Y})");}}
}

例如,对于 P1(1, 1)P2(3, 3) 和 P3(1, 3)P4(3, 1) 这组坐标,通过上述代码可以计算出它们的垂直交点坐标。

再比如,如果两条直线平行,如 P1(1, 1)P2(2, 2) 和 P3(1, 2)P4(2, 1),那么将返回 (NaN, NaN) 表示无垂直交点。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://xiahunao.cn/news/3247640.html

如若内容造成侵权/违法违规/事实不符,请联系瞎胡闹网进行投诉反馈,一经查实,立即删除!

相关文章

Windows 2012安装之实现远程连接

新建虚拟机 点击稍后安装操作系统 点击Microsoft Windows(W) 选择Windows Server 2012 设置虚拟机名称、安装位置 选择你的电脑核数 点击编辑虚拟机设置 点击CD/DVD(SATA) 使用ISO映像文件(M) 配置完之后点击确定 然后开启虚拟机 下一步: 点击现在安装&#xff1a…

【LeetCode】删除排序链表中的重复元素 II

目录 一、题目二、解法完整代码 一、题目 给定一个已排序的链表的头 head , 删除原始链表中所有重复数字的节点,只留下不同的数字 。返回 已排序的链表 。 示例 1: 输入:head [1,2,3,3,4,4,5] 输出:[1,2,5] 示例 …

【单片机毕业设计选题24069】-物联网节水灌溉系统设计

系统功能: 完成基于物联网的节水灌溉系统的电路图以及软件代码编写。要求系统可以通过传感器监测土壤的湿度和环境温湿度,如果土壤湿度低于限值和环境温湿度超过限值,则需开启继电器,打开电机水泵进行供水灌溉;当土壤湿度高于限值…

Python | Leetcode Python题解之第242题有效的字母异位词

题目: 题解: class Solution:def isAnagram(self, s: str, t: str) -> bool:s_c Counter(s)t_c Counter(t)if(len(s_c) ! len(t_c)):return Falseelse:for key, value in s_c.items():if t_c.get(key) ! value:return Falsereturn True

浅谈数学模型在UGC/AIGC游戏数值配置调参中的应用(AI智能体)

浅谈数学模型在UGC/AIGC游戏数值配置调参中的应用 ygluu 卢益贵 关键词:UGC、AIGC、AI智能体、大模型、数学模型、游戏数值调参、游戏策划 一、前言 在策划大大群提出《游戏工厂:AI(AIGC/ChatGPT)与流程式游戏开发》讨论之后就…

【软件建模与设计】-04-软件设计和体系结构概念

目录 1、类与对象 2、信息隐藏 2.1、示例 3、继承和泛化/特化 4、并发处理 4.1、并发对象间的协作 5、设计模式 6、软件体系结构和构件 7、软件质量属性 1、类与对象 一个对象是现实世界中物理的或概念的实体。 一个对象盖了数据(data)以及作用于数据之上的过程(pro…

缓存和数据库双写的四种策略分析

概述 缓存是提升系统性能的极为简便的手段之一。相较而言,数据库(或者 NoSQL 数据库)的运行速度较为迟缓,然而速度在很多时候却是决胜的关键要素。采用缓存能够降低响应时间、减轻数据库负载并且节约成本。 正因如此,往…

HTML2048小游戏

源代码在效果图后面 效果图 源代码 <!DOCTYPE html> <html lang"zh-CN"><head><meta charset"UTF-8"><meta name"viewport" content"widthdevice-width, initial-scale1.0"><title>2048 Game&l…

银河麒麟搭建ftp服务器

1.先 查看系统架构&#xff0c;一般银河麒麟都是arrch64的 lscpu uname -a cat /etc/os-release 去下载对应版本的vsftp.rpm包和ftp包 Index of /NS/ (cs2c.com.cn) 1.安装rpm rpm -ivh *.rpm --nodeps --force #强制安装 2.修改配置文件 vi /etc/vsftpd/vsftpd.conf anon…

【STC89C51单片机】串口通信

【STC89C51单片机】串口通信 串口简介1. 串口接线方式2. 通信过程 相关寄存器1. SBUF&#xff08;Serial Buffer Register&#xff09;2. SCON&#xff08;Serial Control Register&#xff09;3. PCON&#xff08;Power Control Register&#xff09;4. TCON&#xff08;Timer…

北京青蓝智慧科技CCRC-DCO数据合规官:人工智能遭遇寒冬?

人工智能技术是否真正迈入了新纪元&#xff1f; 历史上&#xff0c;人工智能已经经历了多次起伏&#xff0c;每次都伴随着寒冷的冬天。 然而&#xff0c;为什么这一次的技术变革被看作是人类社会重大转型的关键节点呢&#xff1f;在CES 2024上&#xff0c;吴恩达和李飞飞预言了…

【HZHY-AI300G智能盒试用连载体验】RTC示例程序测试

本文首发于&#xff1a;【   】【HZHY-AI300G智能盒试用连载体验】 智能工业互联网网关 - 北京合众恒跃科技有限公司 - 电子技术论坛 - 广受欢迎的专业电子论坛! (elecfans.com) HZHY-AI300G智能盒默认的系统是Ubuntu&#xff0c;这样非常方便使用&#xff0c;接上USB键盘和…

开发一个自己的chrom插件

开发一个自己的chrom插件 一、创建一个文件夹 二、配置文件manifest.json 创建名字为&#xff1a;manifest.json的配置文件&#xff0c;模板如下&#xff1a; {"manifest_version": 3,"name": "Hello World Extension","version": …

如何防范场外个股期权的交易风险?

场外个股期权交易&#xff0c;作为金融衍生品市场的重要组成部分&#xff0c;为投资者提供了更为灵活和多样化的投资策略。然而&#xff0c;其高杠杆、高风险特性也使得投资者在追求高收益的同时&#xff0c;面临着较大的交易风险。为了有效防范这些风险&#xff0c;投资者需要…

生成式之CycleGAN图像风格迁移互换

模型介绍 CycleGAN是一种循环对抗生成网络&#xff0c;用于实现在没有配对示例的情况下学习将图像从一个域转换到另一个域的方法。它的重要应用领域是域迁移&#xff0c;即图像风格迁移。与之前的模型不同&#xff0c;CycleGAN不需要训练数据成对出现&#xff0c;因此可以实现…

沙尘传输模拟教程(基于wrf-chem)

沙尘传输模拟教程(基于wrf-chem) 文章目录 沙尘传输模拟教程(基于wrf-chem)简介实验目的wrf-chem简介 软件准备wps、wrf-chem安装conda安装ncl安装ncap安装 数据准备气象数据准备下垫面数据准备 WPS数据预处理namelist.wps的设置geogrid.exe下垫面处理ungrib.exe气象数据预处理…

AI、ML、DL 和 DS 之间的区别

人工智能 数据分析 数据科学 深度学习 机器学习 神经网络 在本文中&#xff0c;我们将了解 AI&#xff08;人工智能&#xff09;、ML&#xff08;机器学习&#xff09;、DL&#xff08;深度学习&#xff09;和 DS&#xff08;数据科学&#xff09;之间的区别。这些术语经常互换…

K8S 上部署 Emqx

文章目录 安装方式一&#xff1a;快速部署安装方式二&#xff1a;定制化部署1. 使用 Pod 直接部署 EMQX Broker2. 使用 Deoloyment 部署 Pod3. 使用 Services 公开 EMQX Broker Pod 服务4. 通过 kubernetes 自动集群 EMQX MQTT 服务器5. 修改 EMQX Broker 的配置6. 赋予 Pod 访…

第11章 规划过程组(11.5规划资源管理)

第11章 规划过程组&#xff08;四&#xff09;11.4规划质量管理&#xff0c;11.5规划资源管理在第三版教材第414~419页&#xff1b; 图片文字音频方式 视频38 第一个知识点&#xff1a;主要输出 1、质量管理计划 描述如何实施适用的政策、程序和指南以实现质量目标&#xff…

【Socket套接字编程】(实现TCP和UDP的通信)

&#x1f387;&#x1f389;&#x1f389;&#x1f389;点进来你就是我的人了 博主主页&#xff1a;&#x1f648;&#x1f648;&#x1f648;戳一戳&#xff0c;欢迎大佬指点&#xff01; 人生格言: 当你的才华撑不起你的野心的时候,你就应该静下心来学习! 欢迎志同道合的朋友…