1. program z1; var x,y:real; begin writeln('введите х'); readln(x); if x<>2 then begin y:=(2*x+3)/(x-2); writeln('y=',y); end else writeln('не существует'); end.
2. program z1; var s,k,i:integer; begin s:=0; writeln('введите k'); readln(k); for i:=1 to k do if i mod 2<>0 then s:=s+i; writeln(s); end.
Вариант №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.
1. Перевод из десятичной с/с в двоичную с/с осуществляется таким образом: делите число на основание с/c, пока число не будет меньше основания, смотрите на остатки справа налево и записываете их, получается нужное число в двоичной с/c, то есть: 14/2 = 7, остаток 0, 7/2 = 3, остаток 1, 3/2 = 1, остаток 1, 1 < 2, остаток 1. Смотрим на остатки от деления (справа налево): 1110. Это и есть число 14 в двоичной. Запишем:
2. Перевод из восьмеричной с/с в двоичную с/с осуществляется триадами. 3 в двоичной с/c = 11, т.к. триады, то 011 (0 перед числом здесь значения не имеет), 4 в двоичной с/с = 100. Запишем: 3. ⇒ ответ:
program z1;
var x,y:real;
begin
writeln('введите х');
readln(x);
if x<>2 then
begin
y:=(2*x+3)/(x-2);
writeln('y=',y);
end
else
writeln('не существует');
end.
2.
program z1;
var s,k,i:integer;
begin
s:=0;
writeln('введите k');
readln(k);
for i:=1 to k do
if i mod 2<>0 then
s:=s+i;
writeln(s);
end.