计算两点之间的距离可以通过勾股定理实现,这里是一个简单的C语言代码示例,它计算二维空间中两个点之间的距离:
#include <stdio.h>
#include <math.h>
typedef struct {
double x;
double y;
} Point;
double sqrt_fast(double target) {
double left = 1.0;
double right = target;
double result = 0.0;
double epsilon = 0.000001; // 精度要求
while (left <= right) {
double mid = left + (right - left) / 2;
double mid_square = mid * mid;
if (mid_square == target) {
result = mid;
break;
} else if (mid_square < target) {
left = mid + epsilon;
result = mid;
} else {
right = mid - epsilon;
}
}
return result;
}
double distance(Point p1, Point p2) {
double dx = p2.x - p1.x;
double dy = p2.y - p1.y;
return sqrt(dx * dx + dy * dy);
}
int main() {
Point p1 = {0, 0};
Point p2 = {4, 5};
printf("The distance between %f,%f and %f,%f is %f\n", p1.x, p1.y, p2.x, p2.y, distance(p1, p2));
return 0;
}
这段代码首先定义了一个结构体 Point 来表示二维空间中的点,然后定义了一个函数 distance 来计算两点之间的距离。在 main 函数中,我们定义了两个点 p1 和 p2,并打印出它们之间的距离。tips:除了使用库函数sqrt,还可以使用sqrt_fast()函数。