xtu oj 1373 Circle

题目描述

给你两个圆的圆心坐标和半径,请判断一下两个圆是下列哪种情况:

  1. 包含:一个圆在另外一个圆内,两圆无交点
  2. 内切:一个圆在另外一个圆内,一个交点
  3. 相交:两个圆交于两点
  4. 外切:两个圆交于1点,且圆没有嵌套
  5. 相离:圆没有嵌套且没有交点

输入

第一行是一个整数T(1≤T≤1000),表示样例的个数。

每个样例是两行,每行三个整数,x,y,r(1≤x,y,r≤1000),分别表示一个圆的圆心坐标和半径

输出

依次每行输出一个样例的结果,如果包含输出1,内切输出2,相交输出3,,外切输出4,想离输出5。

样例输入

5
0 0 2
0 0 1
0 0 2
1 0 1
0 0 2
1 0 2
0 0 2
3 0 1
0 0 2
4 0 1  

样例输出

1
2
3
4
5

AC代码

#include
#include
int main(){
    int T;
    scanf("%d",&T);
    while(T--){
       int x1,y1,r1,x2,y2,r2;
       scanf("%d%d%d",&x1,&y1,&r1);    
       scanf("%d%d%d",&x2,&y2,&r2);
       float d=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
       if(d==r1+r2)printf("4\n");
       else if(dfabs(r1-r2))printf("3\n");
       else if(d==r1-r2||d==r2-r1)printf("2\n");
       else if(d>r1+r2)printf("5\n");
       else printf("1\n");
    } 
}

你可能感兴趣的:(算法,c#,c语言)