Procedure Go(a : Byte; a4,a9 : boolean; s : String); Begin If (a=Finish) and a4 and a9 then Begin Inc(N); Writeln(s); end else If a<Finish then Begin a4:=a4 or (a=4); a9:=a9 or (a=9); Go(a+1,a4,a9,s+'+1'); Go(a+2,a4,a9,s+'+2'); Go(a*3,a4,a9,s+'*3'); end; end;
Begin N:=0; Go(1,false,false,'1'); Writeln('Всего вариантов: ',N); end.