eremenkou
?>

Изучи предложенный программный код и найди соответствующий сценарий: Спрайт: КотДействие:Переходит от одной чашки с яблоками к другой.Считает общее количество яблок.После каждого посчитанного яблока говорит количество посчитанных яблок.Спрайт: КотДействие:Переходит от одной чашки с яблоками к другой.Считает общее количество яблок.Говорит количество всех яблок.Спрайт: КотДействие:Переходит от одной чашки с яблоками к другой.Считает общее количество яблок.После каждой чашки говорит количество посчитанных яблок.​ щас умру T_T

Информатика

Ответы

alex07071
Вариант №1 (не совсем удачный, как было отмечено в комментариях).

//PascalABC.NET (версия 3.1, сборка 1210 от 29.03.2016)
var n,i,m:integer;
flag:boolean;

begin
  readln(n);
  flag:=false;
  if (n mod 2<>0)then i:=n-1 else i:=n;
  while i>0 do begin  
    if power(2,i)<=n then begin
      write(power(2,i),' '); flag:=true;
    end;
    i:=i-2;
end;
if not flag then writeln(0);
end.

Тест №1
1025
1024 256 64 16 4

Тест №2
1
0

Вариант №2

var a,i,n: integer;
begin
  a:=1;readln(n);
  i:=trunc(log2(n)); //получим степень двойки для n
  //если i нечетное,
  //то первое искомое число получаем путем сдвига влево на i-1 в
  //двоичном представлении числа иначе сдвиг на i
  if (i mod 2)=1 then a:=a shl(i-1) else a:=a shl i;
  //далее получаем числа сдвигая вправо на 2 разряда
  //в двоичном представлении числа
  while a>=2 do begin
    write(a,' ');
    a:=a shr 2;
  end;
end.

Тестовое решение:
2147483647
1073741824 268435456 67108864 16777216 4194304 1048576 262144 65536 16384 4096 1024 256 64 16 4
vuyakovleva

ответ:Вариант №1 (не совсем удачный, как было отмечено в комментариях).

//PascalABC.NET (версия 3.1, сборка 1210 от 29.03.2016)

var n,i,m:integer;

flag:boolean;

begin

 readln(n);

 flag:=false;

 if (n mod 2<>0)then i:=n-1 else i:=n;

 while i>0 do begin  

   if power(2,i)<=n then begin

     write(power(2,i),' '); flag:=true;

   end;

   i:=i-2;

end;

if not flag then writeln(0);

end.

Тест №1

1025

1024 256 64 16 4

Тест №2

1

0

Вариант №2

var a,i,n: integer;

begin

 a:=1;readln(n);

 i:=trunc(log2(n)); //получим степень двойки для n

 //если i нечетное,

 //то первое искомое число получаем путем сдвига влево на i-1 в

 //двоичном представлении числа иначе сдвиг на i

 if (i mod 2)=1 then a:=a shl(i-1) else a:=a shl i;

 //далее получаем числа сдвигая вправо на 2 разряда

 //в двоичном представлении числа

 while a>=2 do begin

   write(a,' ');

   a:=a shr 2;

 end;

end.

Тестовое решение:

2147483647

1073741824 268435456 67108864 16777216 4194304 1048576 262144 65536 16384 4096 1024 256 64 16 4

Ответить на вопрос

Поделитесь своими знаниями, ответьте на вопрос:

Изучи предложенный программный код и найди соответствующий сценарий: Спрайт: КотДействие:Переходит от одной чашки с яблоками к другой.Считает общее количество яблок.После каждого посчитанного яблока говорит количество посчитанных яблок.Спрайт: КотДействие:Переходит от одной чашки с яблоками к другой.Считает общее количество яблок.Говорит количество всех яблок.Спрайт: КотДействие:Переходит от одной чашки с яблоками к другой.Считает общее количество яблок.После каждой чашки говорит количество посчитанных яблок.​ щас умру T_T
Ваше имя (никнейм)*
Email*
Комментарий*

Популярные вопросы в разделе

rada8080
ИванМолчанов
Lavka2017
Ионов202
Salko17
olgakovalsky6
vasilevich-F
missmorozova2
burylin9
s9152992722344
markitandl
vadim1140
yliana
sorokinae
kabinet17