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 equals Y.
We are given a list A of strings. Every string in A is an anagram of every other string in A. How many groups are there?
anagram 这个词的意思被忽略导致我误理解了题意
Intuition#
我们可以在 Ow 的时间内分辨 两个words 是否相似
一种思想是纯使用暴力算法 : n2W 的时间内判断两个单词是否详细
另一种想法是 枚举一个单词的所有相似紧邻 一个单词之多有 C2w 个紧邻
W2 的时间用来枚举所有的可能相似单词  W 时间
这样我们可以使用 ONW3 的时间 列出所有的单词相邻
py2 版本
class DSU(object,N):
    def __init__(self):
        self.par=range(N)
    def find(self,x):
        if(self.par[x]!=x):
            self.par[x]= self.find(par[x])
            return self.par[x]
    def union(self,x,y):
        if(x!=y):
            self.par[self.find(x)]=self.find(y)
class Solution(object):
    def numSimilarGroups(self,A):
        N,w=len(A),len(A[0])   # 分别是词的个数和 词的长度
        def similar(W1,W2):
            diff=0
            for x,y in itertools.izip(W1,W2):
                if x!=y:
                    diff=dfif+1
            return diff <=2
        dsu=DSU(N)
        if(N<W*W): //如果整个词列表较短, 遍历整个词列表进行计算会更快
            for (i1,word1),(i2,word2) in itertools.combinations(enumerate(A),2):#高效的枚举操作 ,也是py支持的非常有用的操作
                if similar(word1,word2):
                    dsu.union(i1,i2)  #使用编号作为合并的索引
        else:
            buckets=collections.defaultdict(set) # values 是set 且具有默认值的字典
            for i,word in enumerate(A):
                L=list(word) # string 调换中间某几个字符顺序的最佳操作
                for j0,j1 in itertools.combinations(xrange(N),2):   组合操作的最佳方式 使用itertools
                    L[j0], L[j1] = L[j1], L[j0]
                    buckets["".join(L)].add(i)
                    L[j0], L[j1] = L[j1], L[j0]
            for i1, word in enumerate(A):
                for i2 in buckets[word]:
                    dsu.union(i1, i2)
             return sum([for dsu.par[x]==x for x in range(N)]) #并查集变通块数量的查询简易方法
以上的代码虽然正确,但是复杂度高 ,不能通过(py3 的方式重写之后 不能通过py3 的测试)
下面是 加速版本
class Solution:
    def numSimilarGroups(self, A):
        SA = set(A)  # to delete duplicate items
        A = list(SA) # make it indexable
        L = len(A)
        base = [i for i in range(L)]
        def find(x):
            if base[x] != x:
                base[x] = find(base[x])
            return base[x]
        def union(x, y):
            base[find(x)] = find(y)
        def check(x, y):
            return sum(a!=b for a, b in zip(A[x], A[y])) == 2
        if L < len(A[0])**2:  # deal with long word with few items
            for i1, i2 in itertools.combinations(range(L), 2):
                if check(i1, i2):
                    union(i1, i2)
        else: # deal with short word with lots of items
            buckets = collections.defaultdict(set)
            for i, word in enumerate(A):
                for i1, i2 in itertools.combinations(range(len(word)), 2):
                    if word[i1] != word[i2]:  # filter, otherwise it will exceed memory limit
                        wl = list(word)
                        wl[i1], wl[i2] = wl[i2], wl[i1]
                        key = "".join(wl)
                        if key in SA:
                            buckets[key].add(i)
            for i, word in enumerate(A):
                for j in buckets[word]:
                    union(i, j)
        return sum(base[x] == x for x in range(L))
可以看到 这里将dsu 单独拿出来使用,
然后在枚举 一个单词的所有邻居的时候 也进行了优化 就是如果这个单词的两个位置不一样 我们才认为是一个合法的邻居。
leetcode 839 Similar String Groups的更多相关文章
- [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 ... 
- Similar String Groups
		Two strings X and Y are similar if we can swap two letters (in different positions) of X, so that it ... 
- 【LeetCode】839. 相似字符串组 Similar String Groups (Python)
		作者: 负雪明烛 id: fuxuemingzhu 公众号:每日算法题 本文关键词:LeetCode,力扣,算法,算法题,字符串,并查集,刷题群 目录 题目描述 解题思路 并查集 代码 刷题心得 欢迎 ... 
- [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 ... 
- 牛客练习赛33 E	tokitsukaze and Similar String (字符串哈希hash)
		链接:https://ac.nowcoder.com/acm/contest/308/E 来源:牛客网 tokitsukaze and Similar String 时间限制:C/C++ 2秒,其他语 ... 
- [LeetCode] Positions of Large Groups 大群组的位置
		In a string S of lowercase letters, these letters form consecutive groups of the same character. For ... 
- [LeetCode] 800. Similar RGB Color 相似的红绿蓝颜色
		In the following, every capital letter represents some hexadecimal digit from 0 to f. The red-green- ... 
- 【LeetCode】字符串 string(共112题)
		[3]Longest Substring Without Repeating Characters (2019年1月22日,复习) [5]Longest Palindromic Substring ( ... 
- 【LeetCode】8. String to Integer (atoi) 字符串转换整数
		作者: 负雪明烛 id: fuxuemingzhu 个人博客: http://fuxuemingzhu.cn/ 公众号:负雪明烛 本文关键词:字符串转整数,atoi,题解,Leetcode, 力扣,P ... 
随机推荐
- 安装Ubuntu16.04卡在logo界面
			问题背景 笔者在使用U盘UEFI模式安装Ubuntu16.04时,遇到一个问题,即在BIOS里的boot设置U盘为第一启动项之后,启动,并没有顺利进入系统,而是卡在了logo界面.(PS:其实我等了它 ... 
- js微信禁止分享
			<script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.0.0.js ... 
- light oj 1098 数学规律
			#include <stdio.h> #include <string.h> #include <stdlib.h> #include <math.h> ... 
- 删除文件夹时提示“You need permission to perform this action。。。”,如何解决?
			Win10系统,有时,要删除某个文件夹,却提示“You need permission to perform this action...” 以下是我Google之后找到的解决方案 1.创建一个文本文 ... 
- centos Python2.6 升级到2.7
			需求: centos 6.x 系统默认Python 版本都是2.6,实际生产环境中需要用到Python 2.7.x Python 2.7 下载地址 [root@ansible package]# wg ... 
- UOJ261 【NOIP2016】天天爱跑步 LCA+动态开点线段树
			UOJ261 [NOIP2016]天天爱跑步 Description 小c同学认为跑步非常有趣,于是决定制作一款叫做<天天爱跑步>的游戏.天天爱跑步是一个养成类游戏,需要玩家每天按时上线, ... 
- https://blog.csdn.net/u012235003/article/details/54576737
			https://blog.csdn.net/u012235003/article/details/54576737 
- js算法之把一个数组按照指定的数组大小分割成若干个数组块
			题目描述: 把一个数组arr按照指定的数组大小size分割成若干个数组块. 例如: chunk([1,2,3,4],2)=[[1,2],[3,4]]; chunk([1,2,3,4,5 ... 
- 微信小程序上传报错:以下文件没有被打包上传: · .gitignore
			简单粗暴的办法就是:找到gitignore文件,把该文件删除掉即可. 在使用Git的过程中,我们喜欢有的文件比如日志,临时文件,编译的中间文件等不要提交到代码仓库,这时就要设置相应的忽略规则,来忽略这 ... 
- Asp.Net 应用程序在IIS发布后无法连接oracle数据库问题的解决方法
			asp.net程序编写完成后,发布到IIS,经常出现的一个问题是连接不上Oracle数据库,具体表现为Oracle的本地NET服务配置成功:用 pl/sql 等工具也可以连接上数据库,但是通过浏览器中 ... 
