这是悦乐书的第344次更新,第368篇原创

01 看题和准备

今天介绍的是LeetCode算法题中Easy级别的第209题(顺位题号是893)。

You are given an array A of strings.

Two strings S and T are special-equivalent if after any number of moves, S == T.

A move consists of choosing two indices i and j with i % 2 == j % 2, and swapping S[i] with S[j].

Now, a group of special-equivalent strings from A is a non-empty subset S of A such that any string not in S is not special-equivalent with any string in S.

Return the number of groups of special-equivalent strings from A.

给定一个字符串数组A。

如果在任意数量的移动之后,两个字符串S和T是特殊相等的,S == T

移动是指选择两个索引i和j,其中i%2 == j%2,并且用S[j]交换S[i]

现在,S是一个特殊相等字符串组,是A的非空子集,使得不存在于S中(但存在于A中)的任意字符串与S中的任何字符串不是特殊相等的。

返回A中特殊相等字符串组的数量。例如:

输入:[“a”,“b”,“c”,“a”,“c”,“c”]

输出:3

说明:3组[“a”,“a”],[“b”],[“c”,“c”,“c”]

输入:[“aa”,“bb”,“ab”,“ba”]

输出:4

说明:4组[“aa”],[“bb”],[“ab”],[“ba”]

输入:[“abc”,“acb”,“bac”,“bca”,“cab”,“cba”]

输出:3

说明:3组[“abc”,“cba”],[“acb”,“bca”],[“bac”,“cab”]

输入:[“abcd”,“cdab”,“adcb”,“cbad”]

输出:1

说明:1组[“abcd”,“cdab”,“adcb”,“cbad”]

注意

  • 1 <= A.length <= 1000

  • 1 <= A [i] .length <= 20

  • 所有A [i]具有相同的长度。

  • 所有A [i]仅包含小写字母。

02 理解题意

起初看这道题的题目描述看的是一脸懵逼,不知道它要表达的是什么意思,更不谈如何解题了。

只能硬着头皮看了,已经记不得看了多少遍了,结合它给的四个例子,终于是明白了它想要表达的意思,上面的中文描述是我在谷歌翻译的基础上做了润色的,方便理解,不信邪的人可以直接看英文描述,可以看到你怀疑人生!

题目说两个字符串S和J可以任意交换字符,但是有个前提i%2 == j%2,也就是说S的奇数位只能和奇数位换,S的偶数位只能和偶数位换,J的交换同理,换完之后要是S和J相等,就是特殊相等。

现在又有个特殊相等字符串组的概念,就是由那些特殊相等字符串组成的小帮派,每个小帮派里面的字符串,都符合上面的转换规则.问A中有多少个这样的小帮派?

结合例四来讲,很快你就会明白题目究竟是个神马意思了。

第四个例子中,A = [“abcd”,“cdab”,“adcb”,“cbad”],最后输出是特殊相等字符串组的数量为1,我们来一起看看这个1是怎么算出来的。

先对"abcd"转换一把,'a''c'可以互换,'b''d'可以互换,题目既然说了是任意互换,也就是说不论先后顺序,那我们就统一按照从小到大的顺序来,转换完之后就变成"ac" + "bd"="acbd"

按照这样的逻辑,对"cdab""adcb""cbad"进行转换后,都变成了"acbd",所以最后只存在1个帮派了,就是"acbd"

03 第一种解法

在处理每个单独的字符串时,利用一个26位长度的int数组,记录每个字符出现的次数,对奇数位、偶数维分开处理,然后将两数组转成一个新的字符串拼接在一起,存入HashSet中,最后特殊相等字符串组的数量就是HashSetsize了。

public int numSpecialEquivGroups(String[] A) {
Set<String> set = new HashSet<String>();
for (String str : A) {
int[] odd = new int[26];
int[] even = new int[26];
for (int i=0; i<str.length(); i++) {
if (i%2 == 0) {
even[str.charAt(i)-'a']++;
} else {
odd[str.charAt(i)-'a']++;
}
}
String newStr = Arrays.toString(odd)+Arrays.toString(even);
set.add(newStr);
}
return set.size();
}

04 第二种解法

我们可以对上面的解法再优化下,只用一个int数组,但是长度变为52,前半部分存偶数位,后半部分村奇数位,最后再转成字符串,存入HashSet中,最后特殊相等字符串组的数量就是HashSetsize了。

public int numSpecialEquivGroups2(String[] A) {
Set<String> set = new HashSet<String>();
for (String str : A) {
int[] count = new int[52];
for (int i=0; i<str.length(); i++) {
count[str.charAt(i)-'a'+26*(i%2)]++;
}
set.add(Arrays.toString(count));
}
return set.size();
}

05 小结

算法专题目前已连续日更超过六个月,算法题文章212+篇,公众号对话框回复【数据结构与算法】、【算法】、【数据结构】中的任一关键词,获取系列文章合集。

以上就是全部内容,如果大家有什么好的解法思路、建议或者其他问题,可以下方留言交流,点赞、留言、转发就是对我最大的回报和支持!

LeetCode.893-特殊相等字符串组(Groups of Special-Equivalent Strings)的更多相关文章

  1. 【LeetCode】839. 相似字符串组 Similar String Groups (Python)

    作者: 负雪明烛 id: fuxuemingzhu 公众号:每日算法题 本文关键词:LeetCode,力扣,算法,算法题,字符串,并查集,刷题群 目录 题目描述 解题思路 并查集 代码 刷题心得 欢迎 ...

  2. [Swift]LeetCode893. 特殊等价字符串组 | Groups of Special-Equivalent Strings

    You are given an array A of strings. Two strings S and T are special-equivalent if after any number ...

  3. [Swift]LeetCode839. 相似字符串组 | Similar String Groups

    Two strings X and Y are similar if we can swap two letters (in different positions) of X, so that it ...

  4. Leetcode(8)字符串转换整数

    Leetcode(8)字符串转换整数 [题目表述]: 请你来实现一个 atoi 函数,使其能将字符串转换成整数. 首先,该函数会根据需要丢弃无用的开头空格字符,直到寻找到第一个非空格的字符为止. 当我 ...

  5. 【js】Leetcode每日一题-子数组异或查询

    [js]Leetcode每日一题-子数组异或查询 [题目描述] 有一个正整数数组 arr,现给你一个对应的查询数组 queries,其中 queries[i] = [Li, Ri]. 对于每个查询 i ...

  6. Equivalent Strings (字符串相等?)

    Equivalent Strings   E - 暴力求解.DFS Time Limit:2000MS     Memory Limit:262144KB     64bit IO Format:%I ...

  7. [LeetCode] 893. Groups of Special-Equivalent Strings 特殊字符串的群组

    You are given an array A of strings. Two strings S and T are special-equivalent if after any number ...

  8. LeetCode 893. Groups of Special-Equivalent Strings (特殊等价字符串组)

    题目标签:String 题目可以让在 偶数位置的 chars 互换, 也可以让 在 奇数位置的 chars 互换. 所以为了 return 正确的 group 数量,需要把 那些重复的 给排除掉. 可 ...

  9. [LeetCode] 839. Similar String Groups 相似字符串组

    Two strings X and Y are similar if we can swap two letters (in different positions) of X, so that it ...

随机推荐

  1. 学习swift从青铜到王者之swift属性09

    1.结构体常量和类常量的存储属性 let p1 = Person1() //p1.age = 88 不允许修改 //p11.name = "yhx1" 不允许修改 var p11 ...

  2. 利用百度地图Android sdk高仿微信发送位置功能

    接触了百度地图开发平台半个月了,这2天试着模仿了微信给好友发送位置功能,对百度地图的操作能力又上了一个台阶 (假设须要完整demo.请评论留下邮箱) (眼下源代码已经不发送,假设须要源代码.加qq31 ...

  3. Client使用c#和odp.net连接server oracle

    http://blog.csdn.net/educast/article/details/6605655 Oracle.DataAccess.dll有2.X版本和4.X版本,VS2008开发用2.X ...

  4. Ansible 详细用法说明(一)

    一.概述 运维工具按需不需要有代理程序来划分的话分两类: agent(需要有代理工具):基于专用的agent程序完成管理功能,puppet, func, zabbix agentless(无须代理工具 ...

  5. Java多线程导致的的一个事物性问题

    业务场景 我们如今有一个类似于文件上传的功能.各个子网站接受业务,业务上传文件,各个子网站的文件须要提交到总网站保存.文件是按批次提交到总网站的,也就是说,一个批次以下约有几百个文件. 考虑到白天提交 ...

  6. SQL 快速参考

    SQL 快速参考 SQL 语句 语法 AND / OR SELECT column_name(s)FROM table_nameWHERE conditionAND|OR condition ALTE ...

  7. C# Json反序列化 数据协定类型 无法反序列化 由于未找到必需的数据成员

    背景今天在使用:C# Json 序列化与反序列化 反序列化的时候出现了以下的错误信息. System.Runtime.Serialization.SerializationException: 数据协 ...

  8. soapUI系列之—-06 testrunner实现自动化测试

    TestRunner为soapUI自带------testrunner.bat/testrunner.sh 实现步骤: 1. 使用soapUI,针对接口文件创建测试用例. 2. 将测试用例保存至本地, ...

  9. 【日常学习】codevs1287 矩阵乘法题解

    转载请注明出处 [ametake版权全部]http://blog.csdn.net/ametake欢迎来看. 先上题目 题目描写叙述 Description 小明近期在为线性代数而头疼,线性代数确实非 ...

  10. Python爬虫开发【第1篇】【Scrapy框架】

    Scrapy 框架介绍 Scrapy是用纯Python实现一个为了爬取网站数据.提取结构性数据而编写的应用框架. Srapy框架,用户只需要定制开发几个模块就可以轻松的实现一个爬虫,用来抓取网页内容以 ...