每日一練(47):找不同

加班猿發表於2022-04-28

title: 每日一練(47):找不同

categories:[劍指offer]

tags:[每日一練]

date: 2022/04/22


每日一練(47):找不同

給定兩個字串 s 和 t ,它們只包含小寫字母。字串 t 由字串 s 隨機重排,然後在隨機位置新增一個字母。請找出在 t 中被新增的字母。

示例 1:

輸入:s = "abcd", t = "abcde"

輸出:"e"

解釋:'e' 是那個被新增的字母。

示例 2:

輸入:s = "", t = "y"

輸出:"y"

提示:

0 <= s.length <= 1000

t.length == s.length + 1

s 和 t 只包含小寫字母

來源:力扣(LeetCode)

連結:https://leetcode-cn.com/probl...

方法一:求和

思路分析

本題是隻新增一個字元,求 s 字串的ASCII值和 t 的ASCII值 再 t - s 的ASCII值得到的就是新增的字元的ASCII值

char findTheDifference(string s, string t) {
    int as = 0, at = 0;
    for (auto ch : s) {
        as += ch;
    }
    for (auto ch : t) {
        at += ch;
    }
    return at - as;
}

方法二:位運算

思路分析

如果將兩個字串拼接成一個字串,則問題轉換成求字串中出現奇數次的字元

異或運算的特性:

  • 異或自己得0,任何數異或0得自己本身;
  • 具有交換律、結合律,例如 1^2^3^4^2^3^1 = (1^1)^(2^2)^(3^3)^4 = 0^0^0^4 = 0^4 = 4;
  • 總結:異或運算擅長找不同。
char findTheDifference(string s, string t) {
    int ret = 0;
    for (auto ch : s) {
        ret ^= ch;
    }
    for (auto ch : t) {
        ret ^= ch;
    }
    return ret;
}

相關文章