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

LeetCode:Find the Difference_389

LeetCode 389. Find the Difference