就是个简单的数学题吧
当 圆心距离 在 半径之差 到 半径之和 之间有交集
两个圆的方程如下
(x - x1)^2 + (y - y1)^2 = r1^2
(x - x2)^2 + (y - y2)^2 = r2^2
两者相减,就得到一个关于 x和y 的一次方程,然后再带入上述任一方程就行了
										
					
	
	
	
	      
程序代码:
#include <stdio.h>
#include <math.h>
int main()
{
    float a=5;
    float b=-1812;
    float c=160020;
    float d=b*b-4*a*c;
    float y1=(-b+sqrt(d))/10;
    float y2=(-b-sqrt(d))/10;
    float x1=410.0-4.0/3.0*y1;
    float x2=410.0-4.0/3.0*y2;
    printf("交点一坐标 (x:%.2f,y:%0.2f)",x1,y1);
    printf("交点二坐标 (x:%.2f,y:%0.2f)",x2,y2);
    printf("验证:\n");
    printf("左侧:%.2f  右侧:%.2f \n",(x1-130)*(x1-130)+(y1-130)*(y1-130),80.0*80.0);
    printf("左侧:%.2f  右侧:%.2f \n",(x2-190)*(x2-190)+(y2-210)*(y2-210),60.0*60.0);
    return 0;
}
/*
 PS C:\Users\Administrator> ./ct
交点一坐标 (x:130.00,y:210.00)交点二坐标 (x:206.80,y:152.40)验证:
左侧:6400.00  右侧:6400.00
左侧:3600.00  右侧:3600.00
 */
										
					
	
程序代码:
from sympy import *
import math
x=Symbol("x")
y=Symbol("y")
solved = solve([(x-130)**2+(y-130)**2-80*80,(x-190)**2+(y-210)**2-60*60], [x, y])
for i, v in enumerate(solved):
    print(f"x{i}: {v[0].round(5)}, y{i}: {v[1].round(3)}")              # 保留 3 位小数
'''
PS C:\Users\Administrator> & C:/Programs/Python/python.exe d:/wp/toutiao.py
x0: 130, y0: 210
x1: 206.80000, y1: 152.400
'''
										
					
	