经典算法详解(10)图中有多少个三角形

简介: 题目:请说出下面图形中包含多少个三角形?请用一个程序完成计算。C++版本 1 #include 2 3 using namespace std; 4 5 const char NO_POINT = '0'; 6 7 //任意的一条线 8 const char *map[]...

题目:请说出下面图形中包含多少个三角形?请用一个程序完成计算。

C++版本

 1 #include<iostream>
 2 
 3 using namespace std;
 4 
 5 const char NO_POINT = '0';
 6 
 7 //任意的一条线
 8 const char *map[] = { "ad","ab","db","ae","aj","ah","ej","eh","jh","af","ak","ai","fk","fi","ki","ag","ac","gc",
 9 "de","df","dg","ef","eg","fg","bj","bk","bg","jk","jg","kg","bh","bi","bc","hi","hc","ic" };
10 //共线的点
11 const char *line[] = { "adb","aejh","afki","agc","defg","bjkg","bhic" };
12 
13 //点是否在线上
14 int contain( const char *str, char a) {
15     int i = 0;
16     while (str[i] != '\0') {        //注意字符使用单引号,字符串是双引号
17         if (str[i] == a)
18             return 1;
19         i++;
20     }
21     return 0;
22 }
23 
24 //三个点是否在一条线上函数
25 int isInALine(const char *str[], char a, char b, char c) {
26     int i ;
27     for (i = 0; i < 7; i++) {
28         if (contain(str[i], a) && contain(str[i], b) && contain(str[i], c)) {
29             return 1;
30         }
31     }
32     return 0;
33 }
34 
35 //两条线的交点函数
36 char getCrossPoint(const char *str1, const char *str2) {
37     if (*str1 == *str2)
38         return *str1;
39     if (*str1 == *(str2 + 1))
40         return *str1;
41     if (*(str1 + 1) == *str2)
42         return *(str1 + 1);
43     if (*(str1 + 1) == *(str2 + 1))
44         return *(str1 + 1);
45     return NO_POINT;
46 }
47 
48 //三条线两两必须有交点,并且三条线不能共线才能构成三角形。
49 int isTriangle(const char *str1, const char *str2, const char *str3) {
50     char Point1, Point2, Point3;
51     Point1 = getCrossPoint(str1, str2);
52     if (Point1 == NO_POINT)
53         return 0;
54     Point2 = getCrossPoint(str1, str3);
55     if (Point2 == NO_POINT)
56         return 0;
57     Point3 = getCrossPoint(str2, str3);
58     if (Point3 == NO_POINT)
59         return 0;
60     if (isInALine(line, Point1, Point2, Point3))
61         return 0;
62     return 1;
63 }
64 
65 int getTriangelCount( const char *str[]) {
66     int i, j, k,count=0;
67     for (i = 0; i < 36; i++) {
68         for (j = i+1; j < 36; j++) {
69             for (k = j+1; k < 36; k++) {
70                 if (isTriangle(str[i], str[j], str[k]))
71                     count++;
72             }
73         }
74     }
75     return count;
76 }
77 
78 int main(int argc, char *argv[]) {
79     cout << getTriangelCount(map);
80     getchar();
81     return 0;
82 }

 解题思路:

(1)给每个交点做标记,如下:

(2)总共有36条线段,如果三条线段两两之间存在交点,但一条线上(已经包含了三条线交于同一点),则可以构成三角形。如下图所示,最左边的构成三角形,右边两个不构成三角形:

(3)故需要有如下一些子函数:求两条线的交点,三个点是否共线等。

相关文章
|
5月前
|
机器学习/深度学习 算法 C#
C# | 凸包算法之Andrew‘s,获取围绕一组点的凸多边形的轮廓点
这篇关于凸包算法的文章,本文使用C#和Andrew’s算法来实现凸包算法。 首先消除两个最基本的问题: 什么是凸包呢? 凸包是一个包围一组点的凸多边形。凸多边形是指多边形中的每个内角都小于180度的多边形。 凸包算法有什么用呢? 凸包算法的作用是找到这个凸多边形,并且使用最少的点来绘制出它的轮廓。凸包算法在计算机图形学、计算几何和机器学习等领域中有着广泛的应用。
64 0
|
7月前
|
算法 测试技术 C++
C++算法:图中的最短环
C++算法:图中的最短环
|
7月前
|
算法 Java 索引
单元格法近似求解多边形最大内接矩形问题【思路讲解+java实现】
单元格法近似求解多边形最大内接矩形问题【思路讲解+java实现】
137 0
|
7月前
|
存储 算法 Java
基于Y向连贯性算法的多边形扫描线生成(适用于凸多边形和凹多边形)【原理+java实现】
基于Y向连贯性算法的多边形扫描线生成(适用于凸多边形和凹多边形)【原理+java实现】
106 0
|
9月前
|
算法
图论:Voronoi图
图论:Voronoi图
103 0
|
10月前
L2-023 图着色问题 (25 分)(图的遍历)
L2-023 图着色问题 (25 分)(图的遍历)
45 0
|
算法
秒懂算法 | 计算几何:圆
计算几何的基础是点积和叉积,它们定义了向量的大小和方向的关系,是其他计算几何概念和算法的出发点。在点积和叉积的基础上,本篇重点介绍圆覆盖。 计算几何题目的代码大多繁琐冗长,因此掌握模板代码是学习计算几何的关键。本篇精心组织了经典的几何模板
18020 1
秒懂算法 | 计算几何:圆
|
算法
|
算法 索引 Python
使用遗传算法解决图着色问题
图着色任务可以简单概括为:为图中的每个节点分配一种颜色,并保证相连接的节点对不会使用相同的颜色,同时,我们希望使用尽可能少的颜色。本文使用遗传算法解决图着色问题。
1729 0
使用遗传算法解决图着色问题
|
机器学习/深度学习 算法 数据可视化
梯度下降法,二维空间三维空间 代码实现
梯度下降法,二维空间三维空间 代码实现
337 0
梯度下降法,二维空间三维空间 代码实现

热门文章

最新文章