
编程,平面上有n个点,求所有各点之间的最长距离。要求定义和调用函数计算距离
输入输出示例:输入点数:5输入5个点的坐标:12.53.23.76.52.35.10.63.61.2最长距离是5.50求高手给个完整的c语言程序解答这道问题!...
输入输出示例:
输入点数:5
输入5个点的坐标:
1 2.5
3.2 3.7
6.5 2.3
5.1 0.6
3.6 1.2
最长距离是5.50
求高手给个完整的c语言程序解答这道问题! 展开
输入点数:5
输入5个点的坐标:
1 2.5
3.2 3.7
6.5 2.3
5.1 0.6
3.6 1.2
最长距离是5.50
求高手给个完整的c语言程序解答这道问题! 展开
展开全部
#include<stdio.h>
#include<math.h>
float fun(float x0,float x1,float y0,float y1)
{
float y;
y = sqrt(pow((x0-x1),2)+pow((y0-y1),2));
return y;
}
int main()
{
float x[5];
float y[5];
int i,j;
float max = 0.0,t = 0.0;
printf("Please input five numbers:\n");
printf("横坐标:");
for(i = 0;i < 5;i++)
scanf("%f",&x[i]);
printf("纵坐标:");
for(i = 0;i < 5;i++)
scanf("%f",&y[i]);
for(i = 0;i < 4;i++)
{
for(j = i;j < 4;j++)
{
t = fun(x[i],x[j+1],y[i],y[j+1]);
if(max<t)
max = t;
}
}
printf("The longest distance = %.2f",max);
return 0;
}
运行通过!!!
是初始化操作(给数组设定好数据)还是自己输入数据,改一下程序就行啦!
#include<math.h>
float fun(float x0,float x1,float y0,float y1)
{
float y;
y = sqrt(pow((x0-x1),2)+pow((y0-y1),2));
return y;
}
int main()
{
float x[5];
float y[5];
int i,j;
float max = 0.0,t = 0.0;
printf("Please input five numbers:\n");
printf("横坐标:");
for(i = 0;i < 5;i++)
scanf("%f",&x[i]);
printf("纵坐标:");
for(i = 0;i < 5;i++)
scanf("%f",&y[i]);
for(i = 0;i < 4;i++)
{
for(j = i;j < 4;j++)
{
t = fun(x[i],x[j+1],y[i],y[j+1]);
if(max<t)
max = t;
}
}
printf("The longest distance = %.2f",max);
return 0;
}
运行通过!!!
是初始化操作(给数组设定好数据)还是自己输入数据,改一下程序就行啦!
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询