По разделам

 

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


Дано множество A из N точек с целочисленными координатами x, y. Порядок на координатной плоскости определим следующим образом: (x1, y1) < (x2, y2), если либо x1 +y1 < x2 +y2, либо x1 +y1 = x2 +y2 и x1 < x2. Расположить точки данного множества по убыванию в соответствии с указанным порядком.

Код (C/C++)

#include <stdio.h>
 
void swap(float a1[], float a2[]){
    a1[0]+=a2[0];
    a2[0]=a1[0]-a2[0];
    a1[0]-=a2[0];
 
    a1[1]+=a2[1];
    a2[1]=a1[1]-a2[1];
    a1[1]-=a2[1];
}
 
int compare (float a1[], float a2[]){
    if ((a1[0]+a1[1]<a2[0]+a2[1])||((a1[0]+a1[1]==a2[0]+a2[1]) && (a1[0]<a2[0]))) return 1;
    else return 0;
}
 
int main(void)
{
    float a[10][2];
    int n;
 
    printf("N: ");
    scanf("%i",&n);
 
    int i;
    for (i=0; i<n; ++i){
        printf("a[%i]:\n",i+1);
        printf("  x : ");
        scanf("%f",&a[i][0]);
        printf("  y : ");
        scanf("%f",&a[i][1]);
    }
 
    int i2, n2=n;
 
    for (i=0; i<n-1;i++){
        --n2;
        for (i2=0; i2<n2; i2++)
            if (compare(a[i2+1],a[i2])==0){
                swap(a[i2+1], a[i2]);
            }
    }
 
    for (i=0; i<n;i++)
    printf("A %i :\n x: %f\n y: %f\n",i+1 , a[i][0],a[i][1]);
 
    return 0;
}

Код (Pascal)

program Array140;
 
var
 A: array [1..10,1..2] of real;
 N,N2,i,i2,i3: integer;
 
Procedure Swap(var X1, Y1, X2, Y2 :Real);
 begin
  X1:=X1+X2;
  X2:=X1-X2;
  X1:=X1-X2;
 
  Y1:=Y1+Y2;
  Y2:=Y1-Y2;
  Y1:=Y1-Y2;
 end;
 
Function Compare(X1,Y1, X2, Y2:real):boolean;
 begin
  if (x1+y1<x2+y2) or ((x1+y1=x2+y2) and (x1<x2)) then Compare:=True
  else Compare:=False;
 end;
 
begin
 Write('N: ');
 Readln(N);
 
 Writeln('A: ');
 for i:=1 to N do
  begin
   write(i,'.x :');
   readln(a[i,1]);
   write(i,'.y :');
   readln(a[i,2]);
  end;
 
 N2:=N;
 for i:=1 to N-1 do
  begin
   i2:=1;
   N2:=N2-1;
   while (i2<=N2) do
    begin
     if Compare(A[i2+1,1],A[i2+1,2],A[i2,1],A[i2,2]) then Swap(A[i2+1,1],A[i2+1,2],A[i2,1],A[i2,2]);
     inc(i2);
    end;
  end;
  for i:=1 to N do writeln(a[i,1]:7:0,' : ',a[i,2]:7:0);
end.
									




Array. Абрамян
Array 1 Просмотров: 10053
Array 2 Просмотров: 6953
Array 3 Просмотров: 5666
Array 4 Просмотров: 4835
Array 5 Просмотров: 6541
Array 6 Просмотров: 4497
Array 7 Просмотров: 4403
Array 8 Просмотров: 4690
Array 9 Просмотров: 4213
Array 10 Просмотров: 3871
Array 11 Просмотров: 4636
Array 12 Просмотров: 3719
Array 13 Просмотров: 3305
Array 14 Просмотров: 2808
Array 15 Просмотров: 4360
Array 16 Просмотров: 3374
Array 17 Просмотров: 3261
Array 18 Просмотров: 4370
Array 19 Просмотров: 2900
Array 20 Просмотров: 4618
Array 21 Просмотров: 2635
Array 22 Просмотров: 2383
Array 23 Просмотров: 2805
Array 24 Просмотров: 2623
Array 25 Просмотров: 2168
Array 26 Просмотров: 2830
Array 27 Просмотров: 2326
Array 28 Просмотров: 3025
Array 29 Просмотров: 1754
Array 30 Просмотров: 2572
Array 31 Просмотров: 2022
Array 32 Просмотров: 2403
Array 33 Просмотров: 1768
Array 34 Просмотров: 2071
Array 35 Просмотров: 1452
Array 36 Просмотров: 1533
Array 37 Просмотров: 3042
Array 38 Просмотров: 1616
Array 39 Просмотров: 1667
Array 40 Просмотров: 1878
Array 41 Просмотров: 1687
Array 42 Просмотров: 1339
Array 43 Просмотров: 1609
Array 44 Просмотров: 1484
Array 45 Просмотров: 1542
Array 46 Просмотров: 1350
Array 47 Просмотров: 1776
Array 48 Просмотров: 2879
Array 49 Просмотров: 1759
Array 50 Просмотров: 1304
Array 51 Просмотров: 2112
Array 52 Просмотров: 1953
Array 53 Просмотров: 1504
Array 54 Просмотров: 1497
Array 55 Просмотров: 1373
Array 56 Просмотров: 1228
Array 57 Просмотров: 1463
Array 58 Просмотров: 1365
Array 59 Просмотров: 1743
Array 60 Просмотров: 1260
Array 61 Просмотров: 1212
Array 62 Просмотров: 2072
Array 63 Просмотров: 1616
Array 64 Просмотров: 1328
Array 65 Просмотров: 1705
Array 66 Просмотров: 1551
Array 67 Просмотров: 1268
Array 68 Просмотров: 2424
Array 69 Просмотров: 1843
Array 70 Просмотров: 1731
Array 71 Просмотров: 1456
Array 72 Просмотров: 1375
Array 73 Просмотров: 1156
Array 74 Просмотров: 1393
Array 75 Просмотров: 1566
Array 76 Просмотров: 1385
Array 77 Просмотров: 1174
Array 78 Просмотров: 1387
Array 79 Просмотров: 1155
Array 80 Просмотров: 1130
Array 81 Просмотров: 1041
Array 82 Просмотров: 929
Array 83 Просмотров: 847
Array 84 Просмотров: 837
Array 85 Просмотров: 985
Array 86 Просмотров: 1453
Array 87 Просмотров: 845
Array 88 Просмотров: 894
Array 89 Просмотров: 934
Array 90 Просмотров: 1722
Array 91 Просмотров: 1082
Array 92 Просмотров: 1328
Array 93 Просмотров: 1326
Array 94 Просмотров: 1138
Array 95 Просмотров: 1543
Array 96 Просмотров: 1263
Array 97 Просмотров: 1138
Array 98 Просмотров: 1851
Array 99 Просмотров: 1090
Array 100 Просмотров: 1053
Array 101 Просмотров: 1101
Array 102 Просмотров: 832
Array 103 Просмотров: 898
Array 104 Просмотров: 877
Array 105 Просмотров: 705
Array 106 Просмотров: 1091
Array 107 Просмотров: 930
Array 108 Просмотров: 993
Array 109 Просмотров: 926
Array 110 Просмотров: 999
Array 111 Просмотров: 872
Array 112 Просмотров: 1686
Array 113 Просмотров: 1205
Array 114 Просмотров: 1049
Array 115 Просмотров: 1164
Array 116 Просмотров: 2114
Array 117 Просмотров: 1601
Array 118 Просмотров: 865
Array 119 Просмотров: 763
Array 120 Просмотров: 939
Array 121 Просмотров: 885
Array 122 Просмотров: 955
Array 123 Просмотров: 912
Array 124 Просмотров: 785
Array 125 Просмотров: 811
Array 126 Просмотров: 750
Array 127 Просмотров: 757
Array 128 Просмотров: 830
Array 129 Просмотров: 834
Array 130 Просмотров: 872
Array 131 Просмотров: 1066
Array 132 Просмотров: 838
Array 133 Просмотров: 753
Array 134 Просмотров: 1176
Array 135 Просмотров: 665
Array 136 Просмотров: 885
Array 137 Просмотров: 763
Array 138 Просмотров: 685
Array 139 Просмотров: 836
Array 140 Просмотров: 1370

Комментарии

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



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