每日一練(47):找不同
阿新 • • 發佈:2022-04-22
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/problems/find-the-difference
方法一:求和
思路分析
本題是隻新增一個字元,求 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得自己本身;
-
具有交換律、結合律,例如 1234231 = (11)(22)(33)4 = 000^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; }