zoukankan      html  css  js  c++  java
  • 判断圆和矩形是否相交C

    Description

    Given a rectangle and a circle in the coordinate system(two edges of the rectangle are parallel with the X-axis, and the other two are parallel with the Y-axis), you have to tell if their borders intersect. 

    Note: we call them intersect even if they are just tangent. The circle is located by its centre and radius, and the rectangle is located by one of its diagonal. 

     

    Input

    The first line of input is a positive integer P which indicates the number of test cases. Then P test cases follow. Each test cases consists of seven real numbers, they are X,Y,R,X1,Y1,X2,Y2. That means the centre of a circle is (X,Y) and the radius of the circle is R, and one of the rectangle's diagonal is (X1,Y1)-(X2,Y2). 
     

    Output

    For each test case, if the rectangle and the circle intersects, just output "YES" in a single line, or you should output "NO" in a single line. 
     

    Sample Input

    2 1 1 1 1 2 4 3 1 1 1 1 3 4 4.5
     

    Sample Output

    YES NO
     
    问题:在一个坐标系中,有一个圆和一个矩形,判断圆和矩形是否相交
       输入圆心坐标,圆的半径,和矩形中一对对角线中两个点的坐标
       
    思路:圆和矩形相交有大概可分为两种情况
       情况一:矩形的顶点在圆内,
       情况二:矩形的顶点不在圆内,矩形的边和圆相交
       判断方法:刚开始想矩形的顶点到圆心的距离小于r就是第一种情况了,后来发现还有一种情圆很大很大以至于矩形在圆里边
       
              刚开始的时候还认为圆心到矩形的每条边的垂直距离小于圆的半径是第二种情况了,
              后来发现圆心(x, y)不满足 (x1 < x < x2)&&(y1 < y < y2)的时候,圆心到矩形每条边的垂直距离也可能小于半径
            所以把这两个判定条件所造成的多出的情况摘出来,然后再判断剩下的情况就行了
     
    代码:
    #include <stdio.h>
    #include <string.h>
    #include <math.h>
    
    using namespace std;
    
    double a, b, xa, ya, xb, yb, r;
    
    double far(double n1, double m1, double n2, double m2)
    {
        double ans;
        ans = (n1 - n2) * (n1 - n2) +(m1 - m2) * (m1 - m2);
        ans = sqrt(ans);
        return ans;
    }
    
    double max(double x, double y)
    {
        if (x > y)
            return x;
        else
            return y;
    }
    
    double min(double x, double y)
    {
        if (x < y)
            return x;
        else
            return y;
    }
    
    int main()
    {
        int T;
        scanf("%d", &T);
        while(T--)
        {
            scanf("%lf%lf%lf%lf%lf%lf%lf", &a, &b, &r, &xa, &ya, &xb, &yb);
            if (
                    far(xa, ya, a, b) < r &&
                    far(xa, yb, a, b) < r &&
                    far(xb, ya, a, b) < r &&
                    far(xb, yb, a, b) < r //矩形在圆里面
                )
            {
                printf("NO
    ");
                continue;
            }
            else if (
                        far(xa, ya, a, b) > r &&
                        far(xa, yb, a, b) > r &&
                        far(xb, ya, a, b) > r &&
                        far(xb, yb, a, b) > r &&
                        far(xa, ya, xb, ya) > 2*r &&
                        far(xa, ya, xa, yb) > 2*r //圆在矩形里面
                    )
            {
                printf("NO
    ");
                continue;
            }
            else if (
                        far(xa, ya, a, b) <= r ||
                        far(xa, yb, a, b) <= r ||
                        far(xb, ya, a, b) <= r ||
                        far(xb, yb, a, b) <= r       //顶点在圆内
                    )
            {
                printf("YES
    ");
                continue;
            }
            else if(
                        (far(xa, b, a, b) <= r && b < max(ya, yb) && b > min(ya, yb))||
                        (far(xb, b, a, b) <= r && b < max(ya, yb) && b > min(ya, yb))||
                        (far(a, ya, a, b) <= r && a < max(xa, xb) && a > min(xa, xb))||
                        (far(a, yb, a, b) <= r && a < max(xa, xb) && a > min(xa, xb))  //顶点不在圆内但是边和圆相交
                    )
            {
                printf("YES
    ");
                continue;
            }
            else
            {
                printf("NO
    ");
                continue;
            }
    
        }
        return 0;
    }
  • 相关阅读:
    Python中的字典
    Python中的元组
    Python中常见的公共方法
    Python中的列表
    Python的循环语句
    Python的流程控制
    Kubernetes-kubectl命令出现错误【The connection to the server localhost:8080 was refused
    nyoj 77-开灯问题 (倍数遍历)
    nyoj 76-超级台阶 (递推)
    nyoj 75-日期计算 (闰年与平年的判断)
  • 原文地址:https://www.cnblogs.com/rain-1/p/4888314.html
Copyright © 2011-2022 走看看