hdu 2609 How many

简介: 点击打开链接hdu 2609 思路:字符串的最小表示 分析: 1 题目要求的是给定n个字符串,找出不同的字符串的个数。由于题目说了,字符串可以进行变换,也就是如果两个字符串相同那么它们的最小表示是相同的。

点击打开链接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;
}



目录
相关文章
|
8月前
|
Java
hdu-2546-饭卡
hdu-2546-饭卡
32 0
|
机器学习/深度学习 算法
|
Java BI
HDU 2034 人见人爱A-B
人见人爱A-B Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submission(s): 77157    Accepted Submission(s): 21509 Problem Description 参加过上个月月赛的同学一定还记得其中的一个最简单的题目,就是{A}+{B},那个题目求的是两个集合的并集,今天我们这个A-B求的是两个集合的差,就是做集合的减法运算。
1165 0