【ICPC-230】hdu 2609 How many

点击打开链接hdu 2609

 

思路:字符串的最小表示

分析:
1 题目要求的是给定n个字符串,找出不同的字符串的个数。由于题目说了,字符串可以进行变换,也就是如果两个字符串相同那么它们的最小表示是相同的。
2 只要求出所有字符串的最小表示,然后利用set存储,最后set的元素个数就是最后的ans

代码:


#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#include<set>
using namespace std;

#define MAXN 210

int n , len;
char String[MAXN];
set<string>s;

/*求最小表示的下标*/
int getMin(){
   int i = 0 , j = 1 , k = 0;

   while(i+k < len && j+k < len){
      if(String[i+k] == String[j+k])
        k++;
      else{
        if(String[i+k] > String[j+k])
          i = i+k+1;
        else
          j = j+k+1;
        k = 0;
        if(i == j)
          j++;
      }
   }
   return min(i , j);
}

/*求出最小表示*/
void getMinString(char *str){
    str[len/2] = '\0';
    s.insert(str);
}

int main(){
   while(scanf("%d" , &n) != EOF){
      s.clear();
      for(int i = 0 ; i < n ; i++){
         scanf("%s" , String);
         
         char tmp[MAXN];
         memcpy(tmp , String , sizeof(String));
         strcat(String , tmp);
         len = strlen(String);/*求出长度*/
         
         int num = getMin();
         getMinString(String+num);
         
      }
      printf("%d\n" , s.size());
   }
   return 0;
}

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值