#include
<
stdio.h
>
#include
<
math.h
>
struct
Point
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
double
x, y, z;
}
;
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
Point d[
16
];
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
double
dis( Point
const
&
a, Point
const
&
b )
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
return
sqrt( ( a.x
-
b.x )
*
(a.x
-
b.x )
+
( a.y
-
b.y )
*
(a.y
-
b.y )
+
(a.z
-
b.z)
*
(a.z
-
b.z) );
}
data:image/s3,"s3://crabby-images/13de6/13de6130588e8a001331bf125b484ea2f97d951e" alt=""
int
main()
data:image/s3,"s3://crabby-images/f86b7/f86b7e502a0580d5e24db72fe38f81dda2bc052d" alt=""
{
for
(
int
i
=
0
; i
<
16
;
++
i ) scanf(
"
%lf%lf%lf
"
,
&
d[i].x,
&
d[i].y,
&
d[i].z );
Point temp;
while
( scanf(
"
%lf%lf%lf
"
,
&
temp.x,
&
temp.y,
&
temp.z), temp.x
!=
-
1
&&
temp.y
!=
-
1
&&
temp.z
!=
-
1
)
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
double
min
=
250
*
250
+
250
*
250
+
250
*
250
+
50
;
int
k
=
-
1
;
for
(
int
i
=
0
; i
<
16
;
++
i )
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
if
( dis( d[i], temp )
<
min )
data:image/s3,"s3://crabby-images/db282/db282e9ea79ad6a7617774c9b676a45b33d46480" alt=""
{
min
=
dis( d[i], temp );
k
=
i;
}
}
printf(
"
(%.0lf,%.0lf,%.0lf) maps to (%.0lf,%.0lf,%.0lf)\n
"
, temp.x, temp.y, temp.z, d[k].x, d[k].y, d[k].z );
}
return
0
;
}
posted on 2008-10-28 22:08
Darren 阅读(436)
评论(0) 编辑 收藏 引用 所属分类:
动态规划