Array135. Даны множества $$A$$ и $$B$$, состоящие соответственно из $$N_1$$ и $$N_2$$ точек (точки заданы своими координатами $$x$$, $$y$$). Найти минимальное расстояние между точками этих множеств и сами точки, расположенные на этом расстоянии (вначале выводится точка из множества $$A$$, затем точка из множества $$B$$).
Решение:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 |
#include <stdio.h> #include <math.h> int main(void) { float a[10][2], b[10][2]; int n1,n2; printf("N1: "); scanf("%i",&n1); printf("N2: "); scanf("%i",&n2); int i; for (i=0; i<n1; ++i){ printf("a[%i]:\n",i+1); printf(" x : "); scanf("%f",&a[i][0]); printf(" y : "); scanf("%f",&a[i][1]); } for (i=0; i<n2; ++i){ printf("b[%i]:\n",i+1); printf(" x : "); scanf("%f",&b[i][0]); printf(" y : "); scanf("%f",&b[i][1]); } int amin=0, bmin=0,i2; float r,rmin=sqrt(pow(a[0][0]-b[0][0],2)+pow(a[0][1]-b[0][1],2)); for (i=0; i<n1; ++i){ for (i2=0; i2<n2; ++i2){ r= sqrt(pow(a[i][0]-b[i2][0],2)+pow(a[i][1]-b[i2][1],2)); if (r < rmin) { rmin=r; amin=i; bmin=i2; } } } printf("R: %f\n",rmin); printf("A %i :\n x: %f\n y: %f\n",amin+1,a[amin][0],a[amin][1]); printf("B %i :\n x: %f\n y: %f\n",bmin+1,b[bmin][0],b[bmin][1]); return 0; } |
Другие задачи из раздела Array можно посмотреть здесь.
Комментарии: