5 в 5,из5 в 7 все 5,в 7 5,еще раз заливаем 5 и все в 7,в 5 теперь 3,переливаем из 5 все в 7 теперь в 7 3,заливаем всю 5 и все наливаем в 7,теперь в 5 1,а в 7 все выливаем,теперь переливаем из 5 в 7 и теперь в 7 у нас 1,теперь заливаем 5 полностью и все переливаем в 7 так как там у нас был 1 теперь 5+1=6
Var f: file of integer; i, n, x, t, k, max: integer; s: integer;
begin randomize; write('n='); readln(n);
assign(f, 'numbers.dat'); rewrite(f);
max := -1; for i := 1 to n do begin x := random(4800) + 20; write(f, x); write(x, ' '); if x > max then max := x; end; writeln;
seek(f, 0); k := 0; while not eof(f) do begin read(f, x); t := x; s := 0; while t > 0 do begin s := s + sqr(t mod 10); t := t div 10; end; if x mod s = 0 then k := k + 1; if x > max - 50 then write(x, ' '); end; writeln;
Пусть исходные координаты чертежника (x;y). Смоделируем алгоритм: 0) (x;y) 1) (x-1;y-2) 2) n раз делается одно и то же: первая координата изменяется на a, затем из нее вычитается 1, вторая координата изменяется на b, затем вычитается 2. В результате координаты равны: (x-1+n*(a-1); y-2+n*(b-2)) 3) (x-1+n*(a-1)-20; y-2+n*(b-2)-12) Концом работы программы является попадание в стартовую позицию. То есть x-1+n*(a-1)-20=x => n*(a-1)=21 y-2+n*(b-2)-12=y => n*(b-2)=14 Тогда n нужно искать среди делителей чисел 21 и 14. Точнее ответом будет НОД(21, 14)=7.