1) Используя модульную арифметику, определите наименьшее значение x, для которого x! div 56! сравнимо с 2 по модулю 11. Операцией div обозначено взятие целой части от деления. В ответ запишите найденное значение x. 2) Используя модульную арифметику, определите наименьшее значение x, для которого x! div 127! сравнимо с 6 по модулю 9. Операцией div обозначено взятие целой части от деления. В ответ запишите найденное значение x.
3) Дано множество объектов X = {33, 38, 56, 89, 85}. Хеш-код hi каждого объекта xi из этого множества вычисляется по формуле hi = xi mod 17, где mod – операция взятия остатка от деления. Определите сумму элементов множества X, для которых возможно возникновение коллизии. Найденную сумму запишите в ответ.
function preobr(s:string):string;var i,j,p,n,sered:integer; gl,zp,slovo:string; m:array [1..80] of string;beginzp:='!?*,.'; gl:='аоуыэяеёюи'; p:=pos(' ',s); i:=0; repeat inc(i); slovo:=copy(s,1,p-1); m[i]:=slovo; delete(s,1,p); p:=pos(' ',s); until p=0; n:=i+1; m[n]:=s; for i:=1 to n do begin s:=m[i]; if pos(s[length(s)],zp)<>0 then p:=length(s)-1 else p:=length(s); sered:=(p div 2)+1; if (not odd(p)) or (p<3) then continue; if pos(s[1],gl)=0 then continue; if pos(s[sered],gl)=0 then continue; if pos(s[p],gl)=0 then continue; s[1]:=UpCase(s[1]); s[sered]:=UpCase(s[sered]); s[p]:=UpCase(s[p]); m[i]:=s+'('+s[1]+','+s[sered]+','+s[p]+')'; end; s:=''; for i:=1 to n do s:=s+m[i]+' '; preobr:=s;end;
beginassign(f,'input.txt'); reset(f);assign(t,'output.txt'); rewrite(t); while not eof(f) do begin readln(f,s); writeln(t, preobr(s) ); end; writeln('Файл успешно записан...'); close(f);close(t);readln;end.