По разделам

 

Решение задачи Array 135


Даны множества A и B, состоящие соответственно из N1 и N2 точек (точки заданы своими координатами x, y). Найти минимальное расстояние между точками этих множеств и сами точки, расположенные на этом расстоянии (вначале выводится точка из множества A, затем точка из множества B).

Код (C/C++)

#include <stdio.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;
}

Код (Pascal)

program Array135;
var
 A,B: array [1..10,1..2] of real;
 R,Rmin:real;
 N1,N2,i,i2,Point1,Point2: integer;
 
begin
 Write('N1: ');
 Readln(N1);
 
 Writeln('A: ');
 for i:=1 to N1 do
  begin
   write(i,'.x :');
   readln(a[i,1]);
   write(i,'.y :');
   readln(a[i,2]);
  end;
 
 Write('N2: ');
 Readln(N2);
 
 Writeln('B: ');
 for i:=1 to N1 do
  begin
   write(i,'.x :');
   readln(b[i,1]);
   write(i,'.y :');
   readln(b[i,2]);
  end;
 
 
 Rmin:=sqrt(sqr(A[1,1]-B[1,1])+sqr(A[1,2]-B[1,2]));
 Point1:=1;
 Point2:=1;
 
 
 for i:=1 to N1 do
  for i2:=1 to N2 do
   begin
    R:=sqrt(sqr(A[i,1]-B[i2,1])+sqr(A[i,2]-B[i2,2]));
    if (R < Rmin) then
     begin
      Rmin:=R;
      Point1:=i;
      Point2:=i2;
     end;
   end;
 
  Writeln ('R:',Rmin,' (',A[Point1,1],':',A[Point1,2],') (',B[Point2,1],':',B[Point2,2],')');
end.
									




Array. Абрамян
Array 1 Просмотров: 10192
Array 2 Просмотров: 7005
Array 3 Просмотров: 5716
Array 4 Просмотров: 4888
Array 5 Просмотров: 6602
Array 6 Просмотров: 4544
Array 7 Просмотров: 4454
Array 8 Просмотров: 4747
Array 9 Просмотров: 4271
Array 10 Просмотров: 3909
Array 11 Просмотров: 4685
Array 12 Просмотров: 3773
Array 13 Просмотров: 3348
Array 14 Просмотров: 2849
Array 15 Просмотров: 4406
Array 16 Просмотров: 3423
Array 17 Просмотров: 3297
Array 18 Просмотров: 4426
Array 19 Просмотров: 2952
Array 20 Просмотров: 4677
Array 21 Просмотров: 2680
Array 22 Просмотров: 2418
Array 23 Просмотров: 2849
Array 24 Просмотров: 2669
Array 25 Просмотров: 2202
Array 26 Просмотров: 2876
Array 27 Просмотров: 2363
Array 28 Просмотров: 3070
Array 29 Просмотров: 1785
Array 30 Просмотров: 2613
Array 31 Просмотров: 2058
Array 32 Просмотров: 2442
Array 33 Просмотров: 1795
Array 34 Просмотров: 2109
Array 35 Просмотров: 1479
Array 36 Просмотров: 1568
Array 37 Просмотров: 3074
Array 38 Просмотров: 1651
Array 39 Просмотров: 1703
Array 40 Просмотров: 1918
Array 41 Просмотров: 1716
Array 42 Просмотров: 1379
Array 43 Просмотров: 1640
Array 44 Просмотров: 1514
Array 45 Просмотров: 1579
Array 46 Просмотров: 1385
Array 47 Просмотров: 1811
Array 48 Просмотров: 2913
Array 49 Просмотров: 1794
Array 50 Просмотров: 1337
Array 51 Просмотров: 2150
Array 52 Просмотров: 1990
Array 53 Просмотров: 1541
Array 54 Просмотров: 1536
Array 55 Просмотров: 1399
Array 56 Просмотров: 1260
Array 57 Просмотров: 1496
Array 58 Просмотров: 1397
Array 59 Просмотров: 1767
Array 60 Просмотров: 1287
Array 61 Просмотров: 1246
Array 62 Просмотров: 2107
Array 63 Просмотров: 1654
Array 64 Просмотров: 1358
Array 65 Просмотров: 1739
Array 66 Просмотров: 1582
Array 67 Просмотров: 1297
Array 68 Просмотров: 2462
Array 69 Просмотров: 1866
Array 70 Просмотров: 1762
Array 71 Просмотров: 1487
Array 72 Просмотров: 1408
Array 73 Просмотров: 1184
Array 74 Просмотров: 1422
Array 75 Просмотров: 1595
Array 76 Просмотров: 1419
Array 77 Просмотров: 1202
Array 78 Просмотров: 1415
Array 79 Просмотров: 1198
Array 80 Просмотров: 1158
Array 81 Просмотров: 1069
Array 82 Просмотров: 954
Array 83 Просмотров: 876
Array 84 Просмотров: 868
Array 85 Просмотров: 1009
Array 86 Просмотров: 1493
Array 87 Просмотров: 870
Array 88 Просмотров: 921
Array 89 Просмотров: 963
Array 90 Просмотров: 1759
Array 91 Просмотров: 1117
Array 92 Просмотров: 1363
Array 93 Просмотров: 1371
Array 94 Просмотров: 1171
Array 95 Просмотров: 1586
Array 96 Просмотров: 1297
Array 97 Просмотров: 1171
Array 98 Просмотров: 1889
Array 99 Просмотров: 1115
Array 100 Просмотров: 1082
Array 101 Просмотров: 1139
Array 102 Просмотров: 861
Array 103 Просмотров: 932
Array 104 Просмотров: 911
Array 105 Просмотров: 742
Array 106 Просмотров: 1115
Array 107 Просмотров: 959
Array 108 Просмотров: 1017
Array 109 Просмотров: 954
Array 110 Просмотров: 1025
Array 111 Просмотров: 900
Array 112 Просмотров: 1726
Array 113 Просмотров: 1247
Array 114 Просмотров: 1082
Array 115 Просмотров: 1203
Array 116 Просмотров: 2166
Array 117 Просмотров: 1637
Array 118 Просмотров: 893
Array 119 Просмотров: 788
Array 120 Просмотров: 969
Array 121 Просмотров: 911
Array 122 Просмотров: 986
Array 123 Просмотров: 938
Array 124 Просмотров: 809
Array 125 Просмотров: 840
Array 126 Просмотров: 779
Array 127 Просмотров: 790
Array 128 Просмотров: 855
Array 129 Просмотров: 863
Array 130 Просмотров: 920
Array 131 Просмотров: 1096
Array 132 Просмотров: 879
Array 133 Просмотров: 776
Array 134 Просмотров: 1236
Array 135 Просмотров: 771
Array 136 Просмотров: 925
Array 137 Просмотров: 889
Array 138 Просмотров: 769
Array 139 Просмотров: 897
Array 140 Просмотров: 1497

Комментарии

Чтобы написать комментарии вам нужно войти в систему или зарегистрироваться



Заявка на расчет