1. 程式人生 > >經典算法詳解(10)圖中有多少個三角形

經典算法詳解(10)圖中有多少個三角形

for getch ali get str1 int getchar 程序 cross

題目:請說出下面圖形中包含多少個三角形?請用一個程序完成計算。

技術分享圖片

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)故需要有如下一些子函數:求兩條線的交點,三個點是否共線等。

經典算法詳解(10)圖中有多少個三角形