leetcode-205 | 同构字符串

205. 同构字符串(Isomorphic Strings)

给定两个字符串 s 和 t,判断它们是否是同构的。
如果 s 中的字符可以被替换得到 t ,那么这两个字符串是同构的。
所有出现的字符都必须用另一个字符替换,同时保留字符的顺序。两个字符不能映射到同一个字符上,但字符可以映射自己本身。

示例1:
输入: s = “egg”, t = “add”
输出: true
示例2:
输入: s = “foo”, t = “bar”
输出: false
示例3:
输入: s = “paper”, t = “title”
输出: true

说明:
你可以假设 s 和 t 具有相同的长度。

思路

方法一: 和上题一样的方式

按照空格分割字符串,存入列表中。
对于模式串:pattern = "egg"str = "add" 分别定义一个下标指针,同步移动。
e-->a
g-->d
存入后,判断下一个模式,如g,看str中指针指向的 是否是d
当然,也要防止出现a-->d b-->d现象。
唯一的不同在于,对非空格分割字符串的列表封装:

def splitPattern(self, p):
        li = []
        for i in p:
            li.append(i)
        return li
class Solution(object):
    def isNotInValue(self, ps, s):
        for i in ps.values():
            if i==s:
                return False
        return True
    def splitPattern(self, p):
        li = []
        for i in p:
            li.append(i)
        return li

    def isIsomorphic(self, pattern, s):
        """
        :type s: str
        :type t: str
        :rtype: bool
        """
        li = self.splitPattern(s)
        #print(li)
        p_len, s_len = len(pattern), len(li)
        if p_len != s_len:
            return False
        #定义同步指针i,j
        i,j = 0,0
        #定义字典存放模式字母对应的字符串
        ps = dict()
        while j<p_len:
            if pattern[i] not in ps:
                #防止出现a-->dog  b-->dog
                if self.isNotInValue(ps, li[j]):
                    ps.update({pattern[i]: li[j]})
                else:
                    return False

            if li[j] == ps.get(pattern[i]):
                j += 1
                i += 1
            else:
                return False
        return True

结果:
执行用时 : 48 ms, 在Isomorphic Strings的Python提交中击败了53.57% 的用户
内存消耗 : 12.4 MB, 在Isomorphic Strings的Python提交中击败了56.62% 的

提交时间状态执行用时内存消耗语言
几秒前通过48 ms12.4MBpython
### 方法二:更简单的方式 简化版,因为特色是这里可以直接用i,j同步指针。 不用像上一题那样,拆分成列表后才能用同步指针。
class Solution(object):
    def isIsomorphic(self, s, t):
        """
        :type s: str
        :type t: str
        :rtype: bool
        """
        i, j = 0, 0
        #长度不等返回False
        s_len, t_len = len(s), len(t)
        if s_len!=t_len:
            return False
        #定义一个结果集
        re = dict()
        while i<s_len:
            if s[i] not in re:
                #同样的可能有a-->t  b-->t出现,我们要避免这种情况
                if t[j] in re.values():
                    return False
                re.update({s[i]:t[j]})

            #当前的s[i]取出的对应的t[j]和t[j]进行判断
            if re[s[i]]!=t[j]:
                return False

            i+=1
            j+=1

        return True

结果:
执行用时 : 40 ms, 在Isomorphic Strings的Python提交中击败了96.81% 的用户
内存消耗 : 12.2 MB, 在Isomorphic Strings的Python提交中击败了64.71% 的用户

提交时间状态执行用时内存消耗语言
几秒前通过40 ms12.2MBpython

   Reprint policy


《leetcode-205 | 同构字符串》 by 梦否 is licensed under a Creative Commons Attribution 4.0 International License
 Previous
leetcode-15 | 3Sum 中等难度 leetcode-15 | 3Sum 中等难度
15. 三数之和(3Sum)给定一个包含 n 个整数的数组 nums,判断 nums 中是否存在三个元素 a,b,c ,使得 a + b + c = 0 ?找出所有满足条件且不重复的三元组。 注意:答案中不可以包含重复的三元组。例如, 给
2019-04-26
Next 
leetcode-290 | 单词模式 leetcode-290 | 单词模式
290. 单词模式(Word Pattern)给定一种 pattern(模式) 和一个字符串 str ,判断 str 是否遵循相同的模式。这里的遵循指完全匹配,例如, pattern 里的每个字母和字符串 str 中的每个非空单词之间存在着
2019-04-26
  TOC