当前位置:首页 » 编程语言 » c语言求两点之间的距离

c语言求两点之间的距离

发布时间: 2025-07-19 23:07:04

Ⅰ 简单c语言编程

如果要考虑4个象限,考虑各种x3y3x4y4, 比较麻烦。
大致思路,计算b点到线L1的距离,计算c点到线L1的距离,
用ang3,ang4 与 ang 的相对位置判断 l1 和 l2 应当相加还是相减得 总距离。
程序如下(没考虑4个象限):
#include<stdio.h>
#include<stdlib.h>
#include<math.h>

void main()
{
double r1,r2;
double R=5.0, ang=1.05;
double Bx,By,P1x,P1y,P2x,P2y,l1,l2,L;
double x3=1,y3=3,x4=8,y4=10;
double ang3,ang4;

ang3 = atan(y3/x3);
ang4 = atan(y4/x4);
printf("input angle in deg: \n");
scanf("%lf",&ang);
ang = ang / 180.0 * 3.14159265;
Bx = R * cos(ang);
By = R * sin(ang);
r1 =( (x3*Bx)+(y3*By)) / (R*R);
P1x = r1 * Bx;
P1y = r1 * By;
l1 = sqrt( (x3-P1x)*(x3-P1x) + (y3-P1y)*(y3-P1y) );
r2 =( (x4*Bx)+(y4*By)) / (R*R);
P2x = r2 * Bx;
P2y = r2 * By;
l2 = sqrt( (x4-P2x)*(x4-P2x) + (y4-P2y)*(y4-P2y) );
if ( (ang3 >= ang) && (ang4 <= ang) ) L= fabs(l2 + l1);
else L = fabs(l2-l1);
printf("distance: %.2lf ",L);
}

热点内容
java返回this 发布:2025-10-20 08:28:16 浏览:588
制作脚本网站 发布:2025-10-20 08:17:34 浏览:884
python中的init方法 发布:2025-10-20 08:17:33 浏览:576
图案密码什么意思 发布:2025-10-20 08:16:56 浏览:762
怎么清理微信视频缓存 发布:2025-10-20 08:12:37 浏览:679
c语言编译器怎么看执行过程 发布:2025-10-20 08:00:32 浏览:1009
邮箱如何填写发信服务器 发布:2025-10-20 07:45:27 浏览:252
shell脚本入门案例 发布:2025-10-20 07:44:45 浏览:110
怎么上传照片浏览上传 发布:2025-10-20 07:44:03 浏览:801
python股票数据获取 发布:2025-10-20 07:39:44 浏览:708