Problem Description
输入两点坐标(X1,Y1),(X2,Y2),计算并输出两点间的距离。
Input
输入数据有多组,每组占一行,由4个实数组成,分别表示x1,y1,x2,y2,数据之间用空格隔开。
Output
对于每组输入数据,输出一行,结果保留两位小数。
Sample Input
0 0 0 1
0 1 1 0
Sample Output
1.00
1.41
输入两点坐标(X1,Y1),(X2,Y2),计算并输出两点间的距离。
Input
输入数据有多组,每组占一行,由4个实数组成,分别表示x1,y1,x2,y2,数据之间用空格隔开。
Output
对于每组输入数据,输出一行,结果保留两位小数。
Sample Input
0 0 0 1
0 1 1 0
Sample Output
1.00
1.41
我开始的代码:
#include<stdio.h>
#include<math.h>
int main()
{
int x1,y1,x2,y2;
int t;
double d;
while(scanf("%d%d%d%d",&x1,&y1,&x2,&y2)!=EOF){
t=(x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
d= sqrt(t);
printf("%.2lf\n",d);
}
return 0;
}
#include<math.h>
int main()
{
int x1,y1,x2,y2;
int t;
double d;
while(scanf("%d%d%d%d",&x1,&y1,&x2,&y2)!=EOF){
t=(x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
d= sqrt(t);
printf("%.2lf\n",d);
}
return 0;
}
结果提交上去显示输出超时!
后来将输入的点由int型改为double型,才AC
#include<stdio.h>
#include<math.h>
int main()
{
double x1,y1,x2,y2;
double t;
double d;
while(scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2)!=EOF){
t=(x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
d= sqrt(t);
printf("%.2lf\n",d);
}
return 0;
}
#include<math.h>
int main()
{
double x1,y1,x2,y2;
double t;
double d;
while(scanf("%lf%lf%lf%lf",&x1,&y1,&x2,&y2)!=EOF){
t=(x1-x2)*(x1-x2)+(y1-y2)*(y1-y2);
d= sqrt(t);
printf("%.2lf\n",d);
}
return 0;
}