Переводим третий байт IP и адреса сети в двоичную систему
50 - 110010
48 - 110000
Так как это байт (а в байте 8 бит), допишем два незначащих нуля к получившимся числам:
00110010 - IP
00110000 - адрес сети
Адрес сети получается с помощью применения поразрядной конъюнкции к маске и IP, проще говоря, при перемножении разрядов маски и IP-адреса. И в маске всегда сначала идут только единицы, а потом только нули. То есть можно записать так:
хххххххх - маска
00110010 - IP
00110000 - адрес сети
где иксы в маске и цифры в IP-адресе - множители, а разряды адреса сети - произведение.
На 3 и 4 месте в маске однозначно должны быть единицы, т.к. если там будут нули, то и в адресе сети будут нули. Плюс к этому, в маске всегда сначала идут только единицы, а потом только нули, то есть можно записать так:
1111хххх - маска
00110010 - IP
00110000 - адрес сети
Второй справа разряд IP-адреса - единица, а адреса сети - ноль, значит в маске может быть только ноль:
1111хх00 - маска
00110010 - IP
00110000 - адрес сети
Оставшиеся два икса могут быть и единицами, и нулями. Нужно наименьшее возможное значение, значит поставим на их место нули:
11110000 - маска
00110010 - IP
00110000 - адрес сети
То есть третий байт маски 11110000, переведём в десятичную - получим 240.
По шагам
0) Изначально A = 1, B = 2, C = 1
1) B = A+B = 1 + 2 = 3, C = C+1 = 2 < 4, возвращаемся
2) B = A+B = 1 + 3 = 4, C = C+1 = 3 < 4, возвращаемся
3) B = A+B = 1 + 4 = 5, C = C+1 = 4 не < 4, выходим
Ответ: B = 5
program picaso; uses crt;
type vector=array[1..100] of integer;
var a:vector;
i,n,s:integer;
begin clrscr;
writeln('n :');readln(n);
for i:=1 to n do
begin
write('значение ',i,' : ');
readln(a[i]);
end;
s:=0;
for i:=1 to n do
if i mod 2 <>0 then s:=s+a[i];
writeln('сумму элементов массива, имеющих нечетное значение: ',s);
readln;
end.