3)
а) 5142_8 = 5 * 8^3 + 1 * 8^2 + 4 * 8^1 + 2 * 8^0 = 2560 + 64 + 32 + 2 = 2658_10
б) В305_16 = 11 * 16^3 + 3 * 16^2 + 0 * 16^1 + 5 * 8^0 = 45056 + 768 + 0 + 5 = 45829_10
в) 10110111_2 = 1 * 2^7 + 0 * 2^6 + 1 * 2^5 + 1 * 2^4 + 0 * 2^3 + 1 * 2^2 + 1 * 2^1 + 1 * 2^0 = 128 + 0 + 32 + 16 + 0 + 4 + 2 + 1 = 183_10
4) 1562_10
1562/2 = 781 и остаток 0
781/2 = 390 и остаток 1
390/2 = 195 и остаток 0
195/2 = 97 и остаток 1
97/2 = 48 и остаток 1
48/2 = 24 и остаток 0
24/2 = 12 и остаток 0
12/2 = 6 и остаток 0
6/2 = 3 и остаток 0
3/2 = 1 и остаток 1
1/2 = 0 и остаток 1
1562_10 = 11000011010_2
1562/8 = 195 и остаток 2
195/8 = 24 и остаток 3
24/8 = 3 и остаток 0
3/8 = 0 и остаток 3
1562_10 = 3032_8
1562/16 = 97 и остаток 10 (A)
97/16 = 6 и остаток 1
6/16 = 0 и остаток 6
1562_10 = 61A_16
const
nmax=100;
var
n,i,j,nn,nz,np,t:integer;
a,an,az,ap:array[1..nmax] of integer;
begin
// формируем массив и выводим его
Write('Количество элементов в массиве: '); Read(n);
for i:=1 to n do begin
a[i]:=Random(11)-5;
Write(a[i],' ')
end;
Writeln;
// разбиваем массив на три подмассива
nn:=0; nz:=0; np:=0;
for i:=1 to n do
if a[i]<0 then begin nn:=nn+1; an[nn]:=a[i] end
else
if a[i]=0 then begin nz:=nz+1; az[nz]:=a[i] end
else begin np:=np+1; ap[np]:=a[i] end;
// сортируем массив с отрицательными элементами по убыванию
for i:=1 to nn-1 do
for j:=1 to nn-1 do
if an[j]<an[j+1] then
begin t:=an[j]; an[j]:=an[j+1]; an[j+1]:=t end;
// сортируем массив с положительными элементами по возрастанию
for i:=1 to np-1 do
for j:=1 to np-1 do
if ap[j]>ap[j+1] then
begin t:=ap[j]; ap[j]:=ap[j+1]; ap[j+1]:=t end;
// формируем новое содержимое массива a
i:=0;
for j:=1 to nz do begin i:=i+1; a[i]:=az[j] end;
for j:=1 to np do begin i:=i+1; a[i]:=ap[j] end;
for j:=1 to nn do begin i:=i+1; a[i]:=an[j] end;
// вывод результата
for i:=1 to n do Write(a[i],' ');
Writeln
end.
Тестовое решение:
Количество элементов в массиве: 15
1 2 5 0 -5 -3 0 0 1 -4 3 -2 -2 0 -5
0 0 0 0 1 1 2 3 5 -2 -2 -3 -4 -5 -5