C语言 求出平面直角坐标系中两点的距离

在这里插入图片描述

#include <math.h>
#include <stdio.h>

double dist(double x1, double y1, double x2, double y2){
	return sqrt((x2 - x1) * (x2 - x1) + (y2 - y1) * (y2 - y1));
}

int main(void){
	double x1, y1;
	double x2, y2;
	
	puts("求两点间的距离。 \n");
	puts("点A: ");
	printf("X坐标:");
	scanf("%lf", &x1);
	printf("Y坐标:");
	scanf("%lf", &y1);
	printf("A (%lf, %lf)\n", x1, y1);
	
	
	puts("点B: ");
	printf("X坐标:");
	scanf("%lf", &x2); 
	printf("Y坐标:");
	scanf("%lf", &y2); 
	printf("B(%lf, %lf)\n", x2, y2);
	
	printf("两点之间的距离d = %f\n", dist(x1, y1, x2, y2));
	
	return 0;
}

运行结果:
在这里插入图片描述
注:
double sqrt(double x)函数:
计算x的平方根(实参为复数时会发生定义域错误)。

使用结构体计算两点的距离
#include <math.h>
#include <stdio.h>
#define sqr(n) ((n) * (n))

typedef struct{
	double x;
	double y;
} Point;

double distance_of(Point pa, Point pb){
	return sqrt(sqr(pa.x - pb.x) + sqr(pa.y - pb.y));
}

int main(void){
	Point crnt, dest;
	
	printf("当前地点的X坐标:");
	scanf("%lf", &crnt.x); 
	
	printf("当前地点的Y坐标:");
	scanf("%lf", &crnt.y); 
	
	printf("目的地点的Y坐标:");
	scanf("%lf", &dest.x); 
	
	printf("目的地点的Y坐标:");
	scanf("%lf", &dest.y); 
	
	printf("到目的地的距离为 %.2f。\n", distance_of(crnt, dest));
	
	return 0; 
}
  • 2
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
可以按照以下步骤编写程序: 1. 定义平面直角坐标系上的点的结构体。 ```c typedef struct { double x; double y; } Point; ``` 2. 读入 n 个点的坐标,存储到结构体数组中。 ```c int n; printf("请输入点的数量:"); scanf("%d", &n); Point points[n]; for (int i = 0; i < n; i++) { printf("请输入第%d个点的坐标(用空格隔开):", i + 1); scanf("%lf %lf", &points[i].x, &points[i].y); } ``` 3. 对这些点的 x 轴坐标排序。可以使用冒泡排序或快速排序等算法,这里演示冒泡排序的方法。 ```c for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (points[j].x > points[j+1].x) { // 交换两个点的坐标 Point temp = points[j]; points[j] = points[j+1]; points[j+1] = temp; } } } ``` 4. 输出排序后的点的 x 轴坐标。 ```c printf("按 x 轴坐标从小到大排序后的点的坐标如下:\n"); for (int i = 0; i < n; i++) { printf("(%lf, %lf)\n", points[i].x, points[i].y); } ``` 完整代码如下: ```c #include <stdio.h> typedef struct { double x; double y; } Point; int main() { int n; printf("请输入点的数量:"); scanf("%d", &n); Point points[n]; for (int i = 0; i < n; i++) { printf("请输入第%d个点的坐标(用空格隔开):", i + 1); scanf("%lf %lf", &points[i].x, &points[i].y); } for (int i = 0; i < n - 1; i++) { for (int j = 0; j < n - i - 1; j++) { if (points[j].x > points[j+1].x) { // 交换两个点的坐标 Point temp = points[j]; points[j] = points[j+1]; points[j+1] = temp; } } } printf("按 x 轴坐标从小到大排序后的点的坐标如下:\n"); for (int i = 0; i < n; i++) { printf("(%lf, %lf)\n", points[i].x, points[i].y); } return 0; } ```
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值