jzoj 2557. 【NOIP2011模拟9.9】单词分类

发布于 2019-03-29  815 次阅读


题目描述

Oliver为了学号英语决定苦背单词,但很快他发现要直接记住杂乱无章的单词非常困难,他决定对单词进行分类。
  两个单词可以分为一类当且仅当组成这两个单词的各个字母的数量均相等。
  例如“AABAC”,它和“CBAAA”就可以归为一类,而和“AAABB”就不是一类。
  现在Oliver有N个单词,所有单词均由大写字母组成,每个单词的长度不超过100.你要告诉Oliver这些单词会被分成几类。

输入

输入文件的第一行为单词个数N,以下N行每行为一个单词。

输出

输出文件仅包含一个数,表示这N个单词分成的类数。

思路

每一个进行一次快排然后for一边就可以了

var
  a:array[0..100000] of string;
  st:string;
  i,j,k,m,n,s,len:longint;
procedure sort(l,r:longint);
var
  i,j:longint;
  t,mid:char;
begin
  i:=l; j:=r;
  mid:=st[random(r-l+1)+l];
  repeat
    while st[i]mid do dec(j);
    if i<=j then
      begin
        t:=st[i];
        st[i]:=st[j];
        st[j]:=t;
        inc(i);
        dec(j);
      end;
  until i>j;
  if i(l,r:longint);
var
  i,j:longint;
  t,mid:string;
begin
  i:=l; j:=r;
  mid:=a[random(r-l+1)+l];
  repeat
    while a[i]mid do dec(j);
    if i<=j then
      begin
        t:=a[i];
        a[i]:=a[j];
        a[j]:=t;
        inc(i);
        dec(j);
      end;
  until i>j;
  if ist then
        begin
          inc(s);
          st:=a[i];
        end;
    end;
  writeln(s);
end.
]]>