program casino;
Uses sysutils;
{$H+}
const lung=1000000;
var N,M,C,w,v,coppie,index:Int64;
temp: AnsiString;
S,S_ruotate:array[0..lung] of AnsiString;
funz_errore : array[0..2000000] of Int64;
function LexicalMinRotation(var x: AnsiString):Int64;
var
len,K,i,j:Int64;
begin
temp:=x+x;
len:=length(x);
for i:=1 to len do funz_errore[i]:=-1; (*inizializzo la funzione errore a -1*)
K:=0;
for j:=1 to len do
begin
i:=1;
while (i <> -1 ) and (x[j mod len] <> x[(k + i + 1 ) mod len]) do
begin
i:=funz_errore[j - k - 1];
if x[j mod len] < x[(k + i + 1) mod len] then k:= j - i - 1;
i:= funz_errore[i];
end;
if (i = -1) and (s[j mod len ] <> s[(k + i+1 ) mod len ]) then
begin
if s[j mod len] < s[(k + i+1 ) mod len] then k:= j;
funz_errore[j - k]:= -1;
end
else
funz_errore[j - k]:= i + 1;
end;
LexicalMinRotation:=k;
end;
begin
(*assign(input, 'input.txt'); reset(input);
assign(output, 'output.txt'); rewrite(output);*)
readln (N,M);
for w:=0 to N-1 do readln(S[w]);
coppie:=0;
for w:=0 to N-1 do
begin
index:=LexicalMinRotation(S[w]);
writeln(index);
S_ruotate[w]:=copy(temp,index,M);
writeln(S_ruotate[w]);
end;
for w:=0 to N-2 do
for v:=w+1 to N-1 do
begin
C:= CompareStr(S_ruotate[w], S_ruotate[v]);
if C=0 then coppie:=coppie+1;
end;
writeln (coppie);
end.
cHJvZ3JhbSBjYXNpbm87ClVzZXMgc3lzdXRpbHM7CnskSCt9CmNvbnN0IGx1bmc9MTAwMDAwMDsKdmFyICBOLE0sQyx3LHYsY29wcGllLGluZGV4OkludDY0OwogICAgIHRlbXA6IEFuc2lTdHJpbmc7CiAgICAgUyxTX3J1b3RhdGU6YXJyYXlbMC4ubHVuZ10gb2YgQW5zaVN0cmluZzsKICAgICBmdW56X2Vycm9yZSA6IGFycmF5WzAuLjIwMDAwMDBdIG9mIEludDY0OwpmdW5jdGlvbiBMZXhpY2FsTWluUm90YXRpb24odmFyIHg6IEFuc2lTdHJpbmcpOkludDY0Owp2YXIgCmxlbixLLGksajpJbnQ2NDsKCmJlZ2luCiAgIHRlbXA6PXgreDsKICAgbGVuOj1sZW5ndGgoeCk7CiAgIGZvciBpOj0xIHRvIGxlbiBkbyBmdW56X2Vycm9yZVtpXTo9LTE7ICgqaW5pemlhbGl6em8gbGEgZnVuemlvbmUgZXJyb3JlIGEgLTEqKQogICBLOj0wOwogICBmb3Igajo9MSB0byBsZW4gZG8KICAgICAgICAgICBiZWdpbgogICAgICAgICAgICAgaTo9MTsKICAgICAgICAgICAgIHdoaWxlIChpIDw+IC0xICkgYW5kICh4W2ogbW9kIGxlbl0gPD4geFsoayArIGkgKyAxICkgbW9kIGxlbl0pIGRvIAogICAgICAgICAgICAgICAgICAgYmVnaW4KICAgICAgICAgICAgICAgICAgICAgaTo9ZnVuel9lcnJvcmVbaiAtIGsgLSAxXTsKICAgICAgICAgICAgICAgICAgICAgaWYgeFtqIG1vZCBsZW5dIDwgeFsoayArIGkgKyAxKSBtb2QgbGVuXSB0aGVuIGs6PSBqIC0gaSAtIDE7CiAgICAgICAgICAgICAgICAgICAgIGk6PSBmdW56X2Vycm9yZVtpXTsgCiAgICAgICAgICAgICAgICAgIGVuZDsKICAgICAgICAgICAgaWYgKGkgPSAtMSkgYW5kIChzW2ogbW9kIGxlbiBdIDw+IHNbKGsgKyBpKzEgKSBtb2QgbGVuIF0pIHRoZW4KICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICBiZWdpbgogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGlmIHNbaiBtb2QgbGVuXSA8IHNbKGsgKyBpKzEgKSBtb2QgbGVuXSB0aGVuIGs6PSBqOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGZ1bnpfZXJyb3JlW2ogLSBrXTo9IC0xOwogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVuZAogICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgIGVsc2UKICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgICAgZnVuel9lcnJvcmVbaiAtIGtdOj0gaSArIDE7CiAgICAgICAgICAgICAgIAogICAgICAgICBlbmQ7ICAgCiBMZXhpY2FsTWluUm90YXRpb246PWs7CiAgICAgCmVuZDsKCmJlZ2luCiAgICgqYXNzaWduKGlucHV0LCAnaW5wdXQudHh0Jyk7IHJlc2V0KGlucHV0KTsKICAgYXNzaWduKG91dHB1dCwgJ291dHB1dC50eHQnKTsgcmV3cml0ZShvdXRwdXQpOyopCiAgIHJlYWRsbiAoTixNKTsKICAgZm9yIHc6PTAgdG8gTi0xIGRvIHJlYWRsbihTW3ddKTsgCiAgIGNvcHBpZTo9MDsgCiAgIGZvciB3Oj0wIHRvIE4tMSBkbwogICAgICAgICAgYmVnaW4KICAgICAgICAgICAgaW5kZXg6PUxleGljYWxNaW5Sb3RhdGlvbihTW3ddKTsKICAgICAgICAgICAgd3JpdGVsbihpbmRleCk7CiAgICAgICAgICAgIFNfcnVvdGF0ZVt3XTo9Y29weSh0ZW1wLGluZGV4LE0pOwogICAgICAgICAgICB3cml0ZWxuKFNfcnVvdGF0ZVt3XSk7CiAgICAgICAgICBlbmQ7IAogICAgZm9yIHc6PTAgdG8gTi0yIGRvICAKICAgICAgICAgICAgIGZvciB2Oj13KzEgdG8gTi0xIGRvCiAgICAgICAgICAgICAgICAgICAgICAgIGJlZ2luCiAgICAgICAgICAgICAgICAgICAgICAgICAgQzo9IENvbXBhcmVTdHIoU19ydW90YXRlW3ddLCBTX3J1b3RhdGVbdl0pOwogICAgICAgICAgICAgICAgICAgICAgICAgIGlmIEM9MCB0aGVuIGNvcHBpZTo9Y29wcGllKzE7CiAgICAgICAgICAgICAgICAgICAgICAgIGVuZDsgCiAgICB3cml0ZWxuIChjb3BwaWUpOwplbmQu