本题要求实现一个函数,对给定平面任意两点坐标(x 1 ,y 1 )和(x 2 ,y 2 ),求这两点之间的距离。 函数接口定义: double dist( double x1, double y1, double x2, double y2 ); 其中用户传入的参数为平面上两个点的坐标(x1, y1)和(x2, y2),函数dist应返回两点间的距离。 裁判测试程序样例: #include <stdio.h> #include <math.h> double dist( double x1, double y1, double x2, double y2 ); int main() { double x1, y1, x2, y2; scanf("%lf %lf %lf %lf", &x1, &y1, &x2, &y2); printf("dist = %.2f\n", dist(x1, y1, x2, y2)); return 0; } /* 你的代码将被嵌在这里 */ 输入样例: 10 10 200 100
时间: 2024-01-22 12:03:39 浏览: 130
改算法可以求任意两点之间的最短距离,只要修改里面的邻接矩阵即可.zip
实现代码如下:
```
#include <stdio.h>
#include <math.h>
double dist(double x1, double y1, double x2, double y2) {
double dx = x2 - x1;
double dy = y2 - y1;
double distance = sqrt(dx * dx + dy * dy);
return distance;
}
int main() {
double x1, y1, x2, y2;
scanf("%lf %lf %lf %lf", &x1, &y1, &x2, &y2);
printf("dist = %.2f\n", dist(x1, y1, x2, y2));
return 0;
}
```
在函数dist中,先计算出两点在x轴和y轴上的距离,然后根据勾股定理计算出两点之间的距离,最后返回距离值。在main函数中,读入四个double类型的变量,将它们作为参数传递给dist函数,并输出dist函数的返回值。
阅读全文