算法题每日一练---第51天:找不同

简介: 给定两个字符串 s 和 t ,它们只包含小写字母。

1.png

一、问题描述


给定两个字符串 st ,它们只包含小写字母。


字符串 t 由字符串 s 随机重排,然后在随机位置添加一个字母。请找出在 t 中被添加的字母。


题目链接:找不同


二、题目要求


样例 1

输入:s="abcd", t="abcde"输出:"e"解释:'e'是那个被添加的字母。


样例 2

输入:s="", t="y"输出:"y"


考察

1.map的简单应用,位运算
2.建议用时15~30min


三、问题分析


本题是位运算的第6题,没了解过位运算相关知识点可以看这一篇文章,讲解比较详细:

算法题每日一练---第45天:位运算


1.map

就像小时候玩的找不同一样,只不过这次只有一个不同,我们可以使用map函数分别统计字符串 st 每个字符出现的次数,如果哪一个字符出现的次数不一样,那就找到咧。

也可以排序之后,逐位对比。


2.位运算

字符如何和位运算靠上关系?如果我们将两个字符串拼接成一个,那么不同的那一个出现的次数肯定是奇数,因为没人配对,所以我们可以使用位运算的异或运算


四、编码实现


1.map

classSolution {
public:
charfindTheDifference(strings, stringt) {
inti;
map<char,int>a,b; //map初始化定义两个数组     for(i=0;i<s.size();i++)//遍历字符串s的字符a[s[i]]++;//统计数目for(i=0;i<t.size();i++)//遍历字符串t的字符b[t[i]]++;//统计数目for(charj='a';j<='z';j++)//只有小写字母        {
if(a[j]!=b[j])//不相同            {
returnj;//输出            }
        }
return0;
    }
};


2.位运算

classSolution {
public:
charfindTheDifference(strings, stringt) {
charch=0;//初始化变量inti;
for(i=0;i<s.size();i++)//异或第一个字符    {
ch=ch^s[i];
    } 
for(i=0;i<t.size();i++)//异或第二个字符    {
ch=ch^t[i];
    } 
returnch;//输出结果    }
};


五、测试结果1.png位运算的内存消耗低了一些。


相关文章
|
2月前
|
算法 Java 程序员
【算法每日一练及解题思路】有n级台阶,一次只能上1级或2级,共有多少种走法?
本文深入解析了“爬楼梯问题”,探讨了递归与迭代两种解法,并提供了Java代码实现。通过分析问题本质,帮助读者理解动态规划技巧,提高解决实际编程问题的能力。关键词:Java, 算法, 动态规划, 爬楼梯问题, 递归, 迭代。
118 0
|
算法
算法题每日一练---第78天:二分查找
给定一个 n 个元素有序的(升序)整型数组 nums 和一个目标值 target
200 1
算法题每日一练---第78天:二分查找
|
存储 算法
|
算法
算法题每日一练---第76天:丑数 l
丑数 就是只包含质因数 2、3 和 5 的正整数。
156 1
算法题每日一练---第76天:丑数 l
|
算法
算法题每日一练---第75天:Nim 游戏
你和你的朋友,两个人一起玩 Nim 游戏。
331 0
算法题每日一练---第75天:Nim 游戏
|
算法
算法题每日一练---第74天:快乐数
编写一个算法来判断一个数 n 是不是快乐数。
186 0
算法题每日一练---第74天:快乐数
|
存储 算法
算法题每日一练---第73天:加一
给定一个由 整数 组成的 非空 数组所表示的非负整数,在该数的基础上加一。
168 0
算法题每日一练---第73天:加一
|
算法
算法题每日一练---第72天:数字 1 的个数
给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。
237 0
算法题每日一练---第72天:数字 1 的个数
|
存储 算法
算法题每日一练---第71天:回文数
回文数是指正序(从左向右)和倒序(从右向左)读都是一样的整数。
166 0
算法题每日一练---第71天:回文数