XTU OJ yuan

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

包含:一个圆在另外一个圆内,两圆无交点
内切:一个圆在另外一个圆内,一个交点
相交:两个圆交于两点
外切:两个圆交于一点,且圆没有嵌套
相离:圆没有嵌套且没有交点
输入
第一行是一个整数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
 
样本值输入
 
抽样输出
 

#include<stdio.h>
#include<math.h>
int max(int r1,int r2){
	if(r1>r2)
	return r1;
	else
	return r2;
}
int min(int r1,int r2){
	if(r1<r2)
	return r1;
	else
	return r2;
}
int main(){
	int T;
	int x1,y1,x2,y2;
	int r1,r2;
	int cnt;
	int n,m;
	double d;//两个圆的圆心距离 
	scanf("%d",&T);
	while(T--){
		cnt=0;
		scanf("%d %d %d",&x1,&y1,&r1);
		scanf("%d %d %d",&x2,&y2,&r2);
		d=sqrt((x1-x2)*(x1-x2)+(y1-y2)*(y1-y2));
		//printf("%lf\n",d);
		n=max(r1,r2);
		m=min(r1,r2);
		if(d>r1+r2){//相离的情况 
			cnt=5;
		}
		if(d==r1+r2){//外切情况 
			cnt=4;
		} 
		if(d<n-m){//包含情况 
			cnt=1;
		} 
		if(d==n-m){//内切情况 
			cnt=2;
		}
		if(d<r1+r2&&d>n-m){//相交情况 
			cnt=3;
		}
		printf("%d\n",cnt); 
	}
	return 0;
} 

思路:数学题,不过要注意要先求出r1和r2哪个大,哪个小,才能用作相减进行比较 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值