字符串分类问题(牛客第二场笔试)

Posted 煎蛋啊

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了字符串分类问题(牛客第二场笔试)相关的知识,希望对你有一定的参考价值。

牛牛有N个字符串,他想将这些字符串分类,他认为两个字符串A和B属于同一类需要满足以下条件:
A中交换任意位置的两个字符,最终可以得到B,交换的次数不限。比如:abc与bca就是同一类字符串。
现在牛牛想知道这N个字符串可以分成几类。

 

#include "stdio.h"
#include <vector>
#include <deque>
#include <stack>
#include<map>
#include<utility>
using namespace std;

class Sort {
public:
  int find(vector<string> res, int n) {
        // write code here
        int count = 0;
        if(n>50)
            return 0;

        map<string,int> stringMap;
        map <string,int>::iterator iter,iterend;
        for(int i=0;i<n;i++)
        {
            sort(res[i].begin(),res[i].end());
            stringMap.insert(pair<string,int>(res[i],res[i].size()));
        }
        iterend = stringMap.end();
        for(iter=stringMap.begin();iter!=iterend;iter++)
        {
            count++;
        }
       /* for(int i=0;i<n;i++)
        {
            for(int j=0;j<res[i].size();j++)
            {
                cout<<res[i][j]<< " ";
            }
            cout<<endl;
        }
        */
        return count;
  }
};
int main() {
    int num;
    string str;
    vector<string> res;
   // while(cin>>num)
    {
        cin>>num;

        for(int i=0;i<num;i++)
        {
            cin>>str;
            res.push_back(str);
        }
    }



    Sort solution;
    int result = solution.find(res,num);
    cout<<"RESULT:"<<result<<endl;
   return 0;
}

 

以上是关于字符串分类问题(牛客第二场笔试)的主要内容,如果未能解决你的问题,请参考以下文章

牛客网秋招模拟笔试第二场(选择题)

2017年校招全国统一模拟笔试(第二场)编程题集合--Python

2022牛客多校第二场CDE

2022牛客多校第二场CDE

题集牛客网·2018年全国多校算法寒假训练营练习比赛(第二场)

微软2017年预科生计划在线编程笔试第二场 EL SUENO