- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
输入:S = {p1, . . . , pn}
, n
二维平面上的点 每个点由其 x 和 y 坐标给出。
为简单起见,我们假设:
原点 (0, 0) 不在 S 中。
如果我们从 S 中任意取三个点,我们就可以组成一个三角形。所以这样可以组成的三角形总数是Θ(n^3)。
通过 (0, 0) 的任何直线 L 至多包含 S 中的一个点。
S 中没有三个点在同一条直线上。
有些三角形包含 (0, 0),有些不包含。
问题:计算包含(0, 0)的三角形的个数。
您可以假设我们有一个时间复杂度为 O(1) 的函数 Test(pi, pj , pk)
给定 S 中的三个点 pi, pj , pk,如果三角形形成,则返回 1 by {pi, pj , pk}
包含 (0, 0),否则返回 0。在 Θ(n^3) 时间内解决问题是微不足道的(只需枚举并测试所有三角形)。
描述一个用 O(n log n) 运行时间解决这个问题的算法。
我对上述问题的分析得出以下结论
有4个坐标(+,+),(+,-),(-,-),(-,+){x和y坐标是否>0}。
让
现在我们只需要对以下组合之间的点进行测试
我现在只需要测试上述集合组合中的点(例如来自 s1 的一个点,来自 s2 的一个点和来自 s3
有人可以指导我吗?
下面添加的图片用于说明为什么只有一些子集 (s1,s2, s4) 可以包含 (0,0) 而有些 (s1,s1,s3) 不能。
最佳答案
我猜我们在同一个类(class)(基于问题的奇怪措辞),所以既然截止日期已经过去,我觉得可以给出我的解决方案。我设法找到了 n log n 算法,正如问题所述,它更多的是巧妙地转换问题,而不是动态编程/DaC 解决方案。
注意:这不是详尽的证明,我把它留给你。
首先,一些视觉观察。取一些明显包含原点的三角形。
然后,将点转换为向量。
说服自己,任意选择三个点,每个点取一个向量,描述一个也包含原点的三角形。
此外,如果您在不包含原点的三角形上执行上述步骤,则沿这些向量的点的任何组合也不包含原点。
从这里得到的要点是,矢量的大小无关紧要,重要的是方向。此外,对问题的提示说“任何线交叉(0 ,0) 只包含 S 中的一个点”,由此我们可以推断出每个向量的方向都是唯一的。
因此,如果只有角度很重要,那么可以得出一些逻辑来确定点的范围,给定两个点,可能形成一个包含原点的三角形。为简单起见,我们假设我们已获取 S 中的所有点并将它们转换为向量,然后对它们进行归一化,有效地使所有点位于单位圆上。
所以,沿着这个圆圈取两点。
然后,从每个点通过原点画一条线到圆的另一边。
由此得出,给定这两个点,任何位于红色圆弧上的点都可以形成一个三角形。
因此我们的算法应该执行以下操作:
取 S 中的每个点。制作一个二级数组 A,并且对于每个点,将沿单位圆 (atan2(x,y)) 的角度添加到 A (0 ≤ Ai ≤ 2π)。我们假设这是 O(n)
按递增方式对 A 排序。 O(n log n),假设我们使用合并排序。
计算每对 (Ai,Aj) 可能出现的三角形数量。这意味着我们计算 Ai + π ≤ Ak ≤ Aj + π 的数量。由于数组已排序,我们可以使用二进制搜索来查找 Ai + π 和 Aj + π 的索引,即 O(2 log n) = O(log n)
但是,我们遇到了一个问题,有 n^2 个点,如果我们必须对每个点进行 O(log n) 搜索,我们有 O(n^ 2 log n)。所以,我们需要再做一个观察。
给定一些 Ai < Aj,我们会说 Tij 描述了可能的三角形数,如上述方法所计算的那样。然后,给定第三个 Ak > Aj,我们知道 Tij ≤ Tik,因为 Ai + π 和 Ak + π 之间的点数必须至少与 Ai + π 和 Aj + π 之间的点数一样多。事实上,它就是 Ai + π 和 Aj + π 之间的计数,加上 Aj + π 和 Ak + π 之间的计数。由于我们已经知道 Ai + π 和 Aj + π 之间的计数,因此我们不需要重新计算它 - 我们只需要计算 Aj + π 和 Ak + π 之间的数,然后加上之前的计数。它遵循:
A(n) = count(A(n),A(n-1)) + count(A(n-1),A(n-2)) + ... + count(A(1) ,A(0))
这意味着我们不需要检查所有 n^2 对,我们只需要检查连续的对 - 所以,只有 n-1。
因此,以上所有可以为我们提供以下伪代码解决方案。
int triangleCount(point P[],int n)
int A[n], C[n], totalCount = 0;
for(i=0...n)
A[i] = atan2(P[i].x,P[i].y);
mergeSort(A);
int midPoint = binarySearch(A,π);
for(i=0...midPoint-1)
int left = A[i] + π, right = A[i+1] + π;
C[i] = binarySearch(a,right) - binarySearch(a,left);
for(j=0...i)
totalCount += C[j]
return totalCount;
关于查找由点集形成的三角形是否包含原点并给出总数的算法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33293828/
SDL3 提供了 SDL_RenderGeometry 函数绘制几何图形,用法和 OpenGL 差不多,先定义顶点数据,然后根据顶点数据绘制几何图形。 绘制三角形的代码如下: std::array
我想在图像上使用三角形类型按钮,但我无法执行此操作... 如何做到这一点? 最佳答案 这个project可以帮你。您可以自定义 UIButton 的形状。 关于iphone - 定制非矩形按钮 三角形
我一直在尝试找出如何使用 Python 制作彩虹三角螺旋。我可以制作一个方形螺旋,但它不会导入颜色。而且它不使用三角形。 输出应该是什么样子: 我取得的成就: 我的代码: import tur
我正在使用 this 研究三角形检测算法文章。我编写了这段代码,但不幸的是,当三角形之间存在交集时,该方法返回 false。 private boolean checkTriangleCollisio
我在资源文件中找到了几个关于如何在 Android 中绘制三角形的答案。但是我没有找到任何可以解释如何更改三角形旋转的内容。 我找到的例子:
对于编码类(class)中的作业,我应该找到一种方法让 Python 制作星号三角形,如下所示: x xx xxx 但是,无论我用我的代码做什么,我都无法做到这一点。最好的我可以得到的是:
我在绘制两个多边形时遇到问题。我想填充两个三角形,但一个大于第二个。我在 winforms 中使用 UserControl。代码: Point[] DOWN = new Point[] {new Po
如何测试三角形和正方形是否相交? 当我们知道它是正方形而不是矩形时,有什么方法可以优化它吗?此外,正方形是轴对齐的,这样应该可以进一步提升性能? 或者我应该把正方形分成三角形,然后对三角形-三角形相交
我有一个方法是画一个多边形,然后将多边形向右旋转90度,使其原来的顶点现在指向右边。 这是绘制多边形(三角形)的代码,但我不知道如何旋转它。 Point[] points = new Point[3]
我知道有高效的多边形裁剪算法(例如 Maillot、Vatti、Greiner-Hormann)。然而,这些算法适用于任意多边形,尽管它们适合我的情况,但在我看来,对像我这样的简单情况使用这种通用算法
我的问题可能很愚蠢,但我没有找到三角形 strip 使用的好例子: http://i.stack.imgur.com/KL8jk.png 像这样的顶点: A: -0.5f, -0.5f, // Bo
我正在尝试创建一个等边三角形,您可以在 fiddle 中看到它: 我的想法是,我将笔放在 (0, 0) 处,然后在 (20, 11) 处画线,但三角形看起来不正确。 最佳答案 您的三角形已被
通过编写一些逻辑代码,只是无法弄清楚如何以所需的形式获得 01 三角形的输出,三角形确实打印出来,但不是根据要求的输出。 import java.util.Scanner; import java
我一直在尝试制作一个简单的 pygame 程序来检查光标是否在三角形内部或外部。我通过找到较大三角形的面积,然后从鼠标位置到所有三个点制作三个内部三角形并找到它们的面积来完成此操作。 根据我的理解,如
我有一个方法 drawTriangle,它在 JAVA 中的 OpenGL 程序的 display() 方法中被引用。 public void drawTriangle(GL gl, int x1,
我正在尝试用 C++ 创建一个程序,该程序将数字的三角形模式放入二维数组中。 示例: 1 3 4 5 9 2 9 4 6 1 顶行是一个数字(整数),三角形的每一行比它上面的行多一
所以我最近一直在尝试学习 OpenGL,遵循了几个文本和视频教程。 我无法绘制三角形,我已经双重和三次检查我是否以正确的顺序执行了所有必要的步骤,但我显然遗漏了一些东西 在添加一些代码之前,我应该声明
我遇到了一个用递归绘制谢尔宾斯基三角形的程序。我如何解释这段代码是调用 sierpinski1 直到 n == 0,然后只绘制 3 个小三角形(每次调用一个三角形),因为 n == 0 是绘制某些东西
我有一个需要 3 个点的函数,我将使用这些点来绘制一个三角形,就好像我在使用 glVertex 函数一样。 但由于我想在避免透视变形的同时对这个三角形进行纹理贴图,我必须对其进行 segmentati
下面的代码应该为三角形添加一个 3d 对象,但我收到错误 Assets/Scripts/MakeTriangle.cs(6,28):错误 CS0120:需要对象引用才能访问非静态成员 `UnityEn
我是一名优秀的程序员,十分优秀!