正文

acm拼凑春联2007-04-30 21:35:00

【评论】 【打印】 【字体: 】 本文链接:http://blog.pfan.cn/lingdlz/25378.html

分享到:

拼凑春联   Problem description 春节到了,春联是必不可少的东西^_^。众所周知,一幅对联的“上联”和“下联”是对偶(也叫对仗)的。例如:上联:九州雨顺千山绿下联:六合风调万户丰 BluePoint不喜欢已有的春联组合,所以此人想从已知的佳句中找出两句对偶的,组合出一些新的春联^_*。图书馆有一个“名句文库”,BluePoint想知道其中的名句一共可以拼凑出多少组不同的春联,请您帮帮忙,好吗?为了简化问题,BluePoint只选择七个字的佳句,并把它们的形式化成了字母(按意群将句子分组、断开)。例如“鲲鹏展翅乾坤大”可化为“AABBCCD”,也可以化为“YYQQZZH”,即字母只起显示结构的作用,与句子内容无关。两个句子按照字母的连续性分段后,如果各成分的字数依次相同,则这两个句子对偶。例如:例如“QBLLLDE”和“DEZZZBF”,将第一句按照字母的连续性分为5段:Q、B、LLL、D、E,每段长度分别为1、1、3、1、1,而第二句经过断句后,各段的长度也分别为1、1、3、1、1,因此这两个句子对偶。注:“AABCCCD”和“EEFBBBE”这类句子也算作对偶:第二个句子中两次出现“E”,但“E”是断开的,所以断句情况仍为:2、1、3、1。由于字母只用来突出结构,所以如果出现两次同样的字母串,则它们表示的春联内容不相同,当然,它们是对偶的。  Input 第一行,一个整数N,2≤N≤100000 以下N行,每行都有一个由七个大写字母组成的字符串,代表一个佳句。  Output 一个整数:这些佳句可以拼凑成的对联的种类数。这个整数占一行。  Sample Input 5ABCCCDALLLMNNODEZZZBFAAABCCDKKKXPPQ  Sample Output 4 Judge Tips “ABCCCDA”和“DEZZZBF”两句形式相同,可以组成1种春联。 “LLLMNNO”、“AAABCCD”和“KKKXPPQ”形式都相同,任取两个共可组成3种春联。综上所述,答案为4。  Problem Source HNU Contest   #include <stdio.h>#include <malloc.h>#include <string.h>#include <stdlib.h> int myCompare(const int *a,const int *b){ if(*a > *b)  return -1; else if(*a < *b)  return 1; return 0;} int main(){ int  i,j,n,set,count,sum,*p; int  meter[] = {1,2,4,8,16,32,64,128};  char str[10],c;  scanf("%d",&n); p = (int*)malloc(n*sizeof(int)); memset(p,0,n*sizeof(int)); for(i = 0; i < n; i++){  scanf("%s",str);  for(set=1,c=str[0],j=0; j < 7; j++){   if(c != str[j])    set = (set ? 0 : 1);   if(set)    p[i] |= meter[j];   c = str[j];  } } qsort(p,n,sizeof(int),myCompare); for(count = sum = 0,i = 1; i < n; i++){  if(p[i] == p[i-1]){   count ++;   sum += count;  }   /* sum += (count-1)*count/2 */  else   count = 0; } printf("%d\n",sum); free(p); return 0;}  

阅读(3812) | 评论(1)


版权声明:编程爱好者网站为此博客服务提供商,如本文牵涉到版权问题,编程爱好者网站不承担相关责任,如有版权问题请直接与本文作者联系解决。谢谢!

评论

loading...
您需要登录后才能评论,请 登录 或者 注册