Leetcode 389 Find the difference
Posted lettuan
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Leetcode 389 Find the difference相关的知识,希望对你有一定的参考价值。
Given two strings s and t which consist of only lowercase letters.
String t is generated by random shuffling string s and then add one more letter at a random position.
Find the letter that was added in t.
Example:
Input: s = "abcd" t = "abcde" Output: e Explanation: ‘e‘ is the letter that was added.
本题的解法很类似single number,由于两个str只有一个字母不同。所以可以用xor。注意使用ord 和 chr 对于char和int之间进行转换。
1 class Solution(object): 2 def findTheDifference(self, s, t): 3 """ 4 :type s: str 5 :type t: str 6 :rtype: str 7 """ 8 ans = 0 9 for x in s: 10 ans ^= ord(x) 11 for y in t: 12 ans ^= ord(y) 13 return chr(ans)
解法二是使用collections.Counter
1 class Solution(object): 2 def findTheDifference(self, s, t): 3 """ 4 :type s: str 5 :type t: str 6 :rtype: str 7 """ 8 ds = collections.Counter(s) 9 dt = collections.Counter(t) 10 return (dt - ds).keys().pop()
以上是关于Leetcode 389 Find the difference的主要内容,如果未能解决你的问题,请参考以下文章
LeetCode 389. Find the Difference
LeetCode_389. Find the Difference
leetcode No389. Find the Difference
leetcode No389. Find the Difference