**242.有效的字母异位词 **
leetcode链接:https://leetcode.cn/problems/valid-anagram/
题目描述:给定两个字符串 s 和 t ,编写一个函数来判断 t 是否是 s 的 字母异位词。
核心思路:主要考察哈希表的数组用法以及ascii码的认识。
点击查看代码
class Solution {
public:
bool isAnagram(string s, string t) {
int result[26] = {0};
for(int i = 0;i < s.size();i++){
result[s[i] - 'a']++;
}
for(int i = 0;i < t.size();i++){
result[t[i] - 'a']--;
}
for(int i = 0;i < 26;i++){//这里应该是完整字母表的长度
if(result[i] != 0){
return false;
}
}
return true;
}
};
点击查看代码
class Solution {
public:
vector<int> intersection(vector<int>& nums1, vector<int>& nums2) {
unordered_set<int> result;
unordered_set<int> set_nums(nums1.begin(),nums1.end());
for(int num : nums2){
if(set_nums.find(num) != set_nums.end()){
result.insert(num);
}
}
return vector<int>(result.begin(),result.end());
}
};
点击查看代码
class Solution {
public:
int getSum(int n){
int sum = 0;
while(n){
sum += (n % 10) * (n % 10);
n /= 10;
}
return sum;
}
bool isHappy(int n) {
unordered_set<int> result;
while(1){
int sum = getSum(n);
if(sum == 1){
return true;
}
else if(result.find(sum) != result.end()){
return false;
}
else{
result.insert(sum);
}
n = sum;//更新n的值
}
}
};
点击查看代码
class Solution {
public:
vector<int> twoSum(vector<int>& nums, int target) {
unordered_map<int,int> map;
for(int i = 0;i < nums.size(); i++){
auto iter = map.find(target - nums[i]);//find查询的是键,用值作键位,索引作值位。
if(iter != map.end()){
return {iter->second,i};//iter->second返回的是kv中的value;
}
map.insert(pair<int,int>(nums[i],i)); //创建的map本质上是pair<int,int>类型,所以操作时也要相同类型
}
return {};
}
};