C# 求n边凸多边形的对角线数量(Find number of diagonals in n sided convex polygon)

多边形的对角线(Diagonal)是一个非常基础且重要的几何概念,它连接了多边形内部的特定顶点。

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

1. 基本定义

对角线 是连接一个多边形中不相邻 (或不相邻边)的两个顶点的线段。

简单来说,对角线是从一个顶点出发,连接到除该顶点本身以及与该顶点直接相邻的两个顶点之外的任何其他顶点的线段。

2. 关键点解析

  • 必须连接顶点: 对角线必须是连接多边形本身的两个顶点。
  • 不能是边: 连接相邻顶点的线段是多边形的(Side),而不是对角线。
  • 位于内部(凸多边形): 对于凸多边形(Convex Polygon),所有对角线都完全位于多边形的内部。
  • 可能位于外部(凹多边形): 对于凹多边形(Concave Polygon),某些对角线可能会穿过多边形的外部区域。

3. 对角线的数量计算公式

对于一个具有 n 个顶点的多边形(n 边形),其对角线的总数量可以通过以下公式精确计算:

公式:n*(n-3)/2

公式推导逻辑:

  1. 从一个顶点出发: 在一个 n 边形中,从任意一个顶点出发,可以引出 n−1 条线段。
  2. 排除非对角线: 这 n−1 条线段中,有 2 条连接到相邻顶点(即边),所以从一个顶点能引出 n−3 条对角线。
  3. 避免重复计数: 由于连接顶点 A 到 B 的对角线与连接 B 到 A 的对角线是同一条线段,我们需要将总数除以 2。

因此,总对角线数量为: n×(n−3)÷2。

4、示例

已知 n > 3,求 n 边凸多边形的对角线数量。根据维基百科的定义,在几何学中,对角线是连接多边形或多面体两个顶点的线段,且这两个顶点不在同一条边上。通俗地说,任何倾斜的直线都称为对角线。

例如:

输入:5

输出:5

解释:五条可能的对角线是:AC、AD、BD、BE、CE

对于一个 n 边凸多边形,从每个顶点出发,我们可以画出 n-3 条对角线,每个顶点都与两个相邻顶点相连。按照这种方法,对于 n 个顶点,总共会有 n*(n-3) 条对角线。但是,由于每条对角线需要计算两次,所以对角线的总数变为 n*(n-3)/2。

以下是上述公式的代码:

// C# function to find number of diagonals

// in n sided convex polygon

using System;

class GFG {

static int numberOfDiagonals(int n)

{

return n * (n - 3) / 2;

}

// driver code to test above function

public static void Main()

{

int n = 5;

Console.Write(n + " sided convex polygon have ");

Console.WriteLine(numberOfDiagonals(n) +

" diagonals");

}

}

// This code is contributed by Sam007

输出 :

5 sided convex polygon have 5 diagonals (五边形凸多边形有5条对角线)

时间复杂度: O(1)

辅助空间: O(1)

如果您喜欢此文章,请收藏、点赞、评论,谢谢,祝您快乐每一天。

相关推荐
0xDevNull18 小时前
Java反射机制深度解析:从原理到实战
java·开发语言·后端
小小亮0118 小时前
Next.js基础
开发语言·前端·javascript
ALex_zry18 小时前
C++网络编程心跳机制与连接保活:长连接稳定性保障
开发语言·网络·c++
Amumu1213819 小时前
Js:正则表达式(二)
开发语言·javascript·正则表达式
米粒119 小时前
力扣算法刷题 Day 27
算法·leetcode·职场和发展
Sgf22719 小时前
ES8(ES2017)新特性完整指南
开发语言·javascript·ecmascript
好大哥呀20 小时前
C++ Web 编程
开发语言·前端·c++
ID_1800790547320 小时前
小红书笔记评论 API,Python 调用示例与完整 JSON 返回参考
java·开发语言
Fuxiao___20 小时前
C 语言核心知识点讲义(循环 + 函数篇)
算法·c#
漫随流水20 小时前
c++编程:反转字符串(leetcode344)
数据结构·c++·算法