每日两题 / 438. 找到字符串中所有字母异位词 && 238. 除自身以外数组的乘积(LeetCode热题100)

438. 找到字符串中所有字母异位词 - 力扣(LeetCode)

记录p串每个字符出现次数

维护与p串等长的滑动窗口,记录其中每个字符的出现次数

每次滑动后将当前次数与p串的次数比较即可

cpp 复制代码
class Solution {
public:
    vector<int> findAnagrams(string s, string p) {
        unordered_map<char, int> mp, cnt;
        for (auto t : p)
            cnt[t] ++ ;
        for (int i = 0; i < p.size() - 1 && i < s.size(); ++ i)
            mp[s[i]] ++ ;
        vector<int> ans;
        for (int r = p.size() - 1, l = 0; r < s.size(); ++ r, ++ l)
        {
            mp[s[r]] ++ ;
            bool flag = true;
            for (auto t : mp)
            {
                if (t.second != cnt[t.first])
                {
                    flag = false;
                    break;
                }
            }
            mp[s[l]] -- ;
            if (flag) ans.push_back(l);
        }
        return ans;
    }
};

238. 除自身以外数组的乘积 - 力扣(LeetCode)

维护"前缀和"与"后缀和"数组即可

由于用nums作为前缀和数组,ans作为后缀和数组,即可达到空间复杂度为 O ( 1 ) O(1) O(1) 的要求

cpp 复制代码
class Solution {
public:
    vector<int> productExceptSelf(vector<int>& nums) {
        vector<int> ans = nums;
        for (int i = 1; i < nums.size(); ++ i)
            nums[i] *= nums[i - 1];
        for (int i = ans.size() - 2; i >= 0; -- i)
            ans[i] *= ans[i + 1];
        for (int i = 0; i < ans.size(); ++ i)
        {
            if (i == 0) ans[i] = ans[i + 1];
            else if (i == ans.size() - 1) ans[i] = nums[i - 1];
            else ans[i] = nums[i - 1] * ans[i + 1];
        }
        return ans;
    }
};
相关推荐
YaraMemo4 分钟前
一文带你区分全局最优解和帕累托最优解
算法·5g·信息与通信·信号处理
白夜111713 分钟前
C++(标签派发 Tag Dispatching)
开发语言·c++·笔记·算法
YaraMemo42 分钟前
数学优化问题中的三大转化:多目标转化为单目标,多变量转化为单变量,有约束转化为无约束
人工智能·算法·5g·信息与通信·信号处理
Ailan_Anjuxi1 小时前
【附Python源码】使用minGPT训练自己的小型GPT语言模型
算法
QuZero1 小时前
StampedLock Mechanism
java·算法
云泽8081 小时前
二叉树高阶笔试算法题精讲(二):非递归遍历与序列构造全解析
c++·算法·面试
小O的算法实验室2 小时前
2026年ESWA,基于固定机巢的无人机输电杆塔、变电站与配电杆混合巡检任务分配与路径规划,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
sali-tec4 小时前
C# 基于OpenCv的视觉工作流-章60-点点距离
图像处理·人工智能·opencv·算法·计算机视觉
nlpming4 小时前
OpenCode Skills 文档
算法
无限进步_4 小时前
二叉搜索树完全解析:从概念到实现与应用场景
c语言·开发语言·数据结构·c++·算法·github·visual studio