正文

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
5
ABCCCDA
LLLMNNO
DEZZZBF
AAABCCD
KKKXPPQ

 
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;
}

 

阅读(3625) | 评论(1)


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

评论

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