打卡记录
查找和替换模式(哈希表 / find函数查询重复程度)
1.hash表双映射检测是否存在相同映射。
2.利用string的find函数返回下标来检测对应字符串的重复程度(妙)。
cpp
class Solution {
public:
vector<string> findAndReplacePattern(vector<string>& words, string pattern) {
auto match = [&](string& s, string& p) -> bool
{
unordered_map<char, char> hash;
for (int i = 0; i < s.size(); ++i)
{
char x = s[i], y = p[i];
if (!hash.count(x)) hash[x] = y;
else if (hash[x] != y) return false;
}
return true;
};
vector<string> ans;
for (auto& word : words)
if (match(word, pattern) && match(pattern, word)) ans.push_back(word);
return ans;
}
};
cpp
class Solution {
public:
vector<string> findAndReplacePattern(vector<string>& words, string pattern) {
vector<string> ans;
auto match = [&](string& s, string& p) -> bool
{
for (int i = 0; i < s.size(); ++i)
if (s.find(s[i]) != p.find(p[i])) return false;
return true;
};
for (auto& word : words)
if (match(word, pattern)) ans.push_back(word);
return ans;
}
};
划分数组使最大差为 K(排序 + 贪心 + 移动窗口)
由于求子序列的最大值与最小值,因此其顺序可以打乱,可以直接使用sort快排,然后贪心采用移动窗口来求最小分组数。
cpp
class Solution
{
public:
int partitionArray(vector<int>& nums, int k)
{
int n = nums.size();
sort(nums.begin(), nums.end());
int res = 0, l = 0, r = 0;
while (r < n)
{
if (nums[l] + k >= nums[r]) r++;
else
{
res++;
l = r++;
}
}
if (l < r) res ++;
return res;
}
};