"((7 - 2 - 2)^2 )^2 - 2 = 79"
#Ruby22
def f0(number, log)
return [number * number, "(" + log + ")^2 "]
end
def f1(number, log)
return [number - 2, log + " - 2"]
end
end_num = 79
for n in 1..5
for i in 0..2**n-1
s = ("000000000000000000000000000000" + i.to_s(2))[-n..-1]
start_num = 7
log = start_num.to_s
for k in 0..s.size-1
start_num, log = f0(start_num, log) if s[k] == "0"
start_num, log = f1(start_num, log) if s[k] == "1"
# break if start_num > end_num
end
# p [start_num, log, s, n]
if start_num == end_num then
log += " = " + end_num.to_s
p log
end
end
end
1818 - может получиться, т.к. 18 = 9 + 9, порядок невозрастания сохранен.
189 - может получиться (как 18 и 9)
183 - тоже может
1918 - не может, т.к. сумма двух цифр не может быть больше 18
1819 - нет по той же причине, + нарушен порядок
318 - нет. Если представить его как 3 и 18, то нарушен порядок. Если как 31 и 8, то 31 превосходит максимально возможную сумму.
918 - нет по тем же причинам
118 - может, как 11 и 8
<span>Всего базовых цветов три, поэтому при кодировке каждого из них двумя битами мы имеем кодировку цвета шестью, а значит 2^6 = 64 различных цветов. </span>
<span>Program Pr1;
uses crt;
var stroka:string;
i,k,x:integer;
mas:array[byte] of integer;
Begin
clrscr;
readln(stroka);</span><span>i:=1;
repeat</span><span>val(stroka[i],k,x);
mas[i]:=k;
i:=i+1;</span><span>until i=length(stroka);
x:=0;
for i:=1 to length(stroka) do x:=x+mas[i];
if x=10 then writeln('TRUE')
else writeln('ELSE');
end.</span>