怎么算图中有多少个三角形_贪心算法经典例题

怎么算图中有多少个三角形_贪心算法经典例题题目:请说出下面图形中包含多少个三角形?请用一个程序完成计算。C++版本解题思路:(1)给每个交点做标记,如下:(2)总共有36条线段,如果三条线段两两之间存在交点,但一条线上(已经包含了三条

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

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

怎么算图中有多少个三角形_贪心算法经典例题

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)故需要有如下一些子函数:求两条线的交点,三个点是否共线等。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/166604.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Eureka集群环境搭建

    Eureka集群环境搭建前言:Eureka已经停止更新了,在新的项目中,不推荐使用,通过对周阳老师视频的学习,本篇文章主要是简单介绍下Eureka,以及如何搭建集群环境的Eureka,让大家对Eureka有个初步的了解。1.什么是EurekaEureka是Netflix开发的,一个基于REST服务的,服务注册与发现的组件,以实现中间层服务器的负载平衡和故障转移。它主要包括两个组件:EurekaServer和EurekaClientEurekaClient:一个Java

    2022年6月1日
    41
  • jemter安装mysql数据驱动JDBC

    jemter安装mysql数据驱动JDBC

    2021年5月23日
    103
  • 四大内置核心函数式接口

    四大内置核心函数式接口

    2021年11月12日
    45
  • c语言random函数在vc,C++ 中随机函数random函数的使用方法

    c语言random函数在vc,C++ 中随机函数random函数的使用方法C++中随机函数random函数的使用方法一、random函数不是ANSIC标准,不能在gcc,vc等编译器下编译通过。可改用C++下的rand函数来实现。1、C++标准函数库提供一随机数生成器rand,返回0-RAND_MAX之间均匀分布的伪随机整数。RAND_MAX必须至少为32767。rand()函数不接受参数,默认以1为种子(即起始值)。随机数生成器总是以相同的种子开始,所以形成…

    2022年6月4日
    40
  • pytest 执行用例_测试用例一般执行多少次

    pytest 执行用例_测试用例一般执行多少次前言平常我们功能测试用例非常多时,比如有1千条用例,假设每个用例执行需要1分钟,如果单个测试人员执行需要1000分钟才能跑完当项目非常紧急时,会需要协调多个测试资源来把任务分成两部分,于是执行时间

    2022年7月30日
    5
  • android自定义滑块解锁,android 滑动解锁

    android自定义滑块解锁,android 滑动解锁通过android自定义View实现横向的滑动解锁,1、滑动到中间会自动返回到原始的位置,2、滑动到底部会自动解锁,会触发解锁的回调;首先看效果图如下:实现以上部分一共分为三部分:其中背景通过shape.xml实现滑动的锁是一张图片文字通过Paint绘制在中间,高度可定制主要介绍一下实现的主要部分:(1)有自定义的属性如下:(2)重写ondraw()方法,绘制文字和锁:@Overrideprote…

    2022年6月28日
    21

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号