检查两个圆盘是否在 C 中重叠

标签 c algorithm geometry

我必须输出非重叠光盘的数量。据说如果至少有一个点重叠(它们接触),则两个圆盘重叠。我使用的重叠条件:
第一个输入是我应该从键盘读取的光盘数量。接下来的 n 行输入包含三个整数、x、y 坐标和该圆的半径。
问题是我的输出不正确,我尝试了各种条件来检查光盘是否重叠,但每次我都得到不同的结果。比如输入如下数据时,输出为5,而本应为3。

10
0 0 5
1 7 1
6 0 3
-12 9 10
8 8 6
5 3 4
3 2 2
7 -10 7
3 15 2
-9 -7 7

#include <stdio.h>
#include <stdlib.h>
#include <math.h>

int **readDiscs(int n) //reading discs data into array
{
    int **discs = (int **) calloc(n, sizeof(int *));

    for (int i = 0; i < n; i++)
    {
        discs[i] = (int *) calloc(3, sizeof(int));
        for (int j = 0; j < 3; j++)
            scanf("%d", &discs[i][j]);
    }
    return (discs);
}

int checkOverlap(int **discs, int length)
{
    int *overlaps = (int *) calloc(length, sizeof(int));
    int k = 0, R1, R2, X1, X2, Y1, Y2;
    for (int i = 0; i < length; i++)
        for (int j = i + 1; j < length; j++)
        {
            R1 = discs[i][2];
            R2 = discs[j][2];
            X1 = discs[i][0];
            X2 = discs[j][0];
            Y1 = discs[i][1];
            Y2 = discs[j][1];
            if (sqrt(pow(X2 - X1, 2) + pow(Y2 - Y1, 2)) <= (R1 + R2))   //if the distance is less or equal to radius,
                overlaps[i] = 1;                                        //then they overlap or at least touch
        }
    for (int f = 0; f < length; f++)
        if (overlaps[f] == 0)
            k++;
    free(overlaps);
    return (k);
}

int main(int argc, char *argv[])
{
    int **discs;
    int n;
    scanf("%d", &n);
    discs = readDiscs(n);
    printf("%d\n", checkOverlap(discs, n));
    free(discs);
    return (0);
}

最佳答案

您需要通过注意如果 ij 重叠来修复您的搜索,您应该为两个磁盘都记录下来。因此,当重叠条件为真时,您应该有两个分配。

假设磁盘 1 和 4(共 4 个)重叠,但磁盘 2 和磁盘 3 都不与任何磁盘重叠。你记录了 1 重叠(与 4),但你从未记录 4 与 1 重叠。

关于检查两个圆盘是否在 C 中重叠,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/46622366/

相关文章:

algorithm - Minimax 算法的优点/缺点

Java Line2D 线相交损坏

c++ - 是否可以使用三元运算符 "?"来填充 C/C++ 中的数组列表?

C:二叉树,内存分配

c - 读取文件,修改每一行,将其存储到缓冲区中,一次打印

c++ - 想要在Hudson C/C++上工作

php - 在 PHP 中对数组进行分组

algorithm - C-SAT 和 SAT 的区别?

C++在循环中插入更多 "\t"

geometry - 与两点相交的圆心