408算法题leetcode--第10天

643. 子数组最大平均数 I

cpp 复制代码
class Solution {
public:
    double findMaxAverage(vector<int>& nums, int k) {
        double ret = 0, temp = 0;
        size_t size = nums.size();
        for(int i = 0; i < k; i++){
            temp += nums[i];
        }
        ret = temp;
        // 进,出
        for(size_t i = k; i < size; i++){
            temp = temp + nums[i] - nums[i - k];
            ret = max(temp, ret);
        }
        return ret / k;
    }
};

567. 字符串的排列

cpp 复制代码
class Solution {
public:
    bool checkInclusion(string s1, string s2) {
        // 滑动窗口:大小为s1.size()
        // 相等:两个字符串的字符种类和次数都相同
        int s1_size = s1.size(), s2_size = s2.size();
        if(s1_size > s2_size){
            return false;
        }
        vector<int>hash_s1(26), hash_s2(26);
        for(int i = 0; i < s1_size; i++){
            hash_s1[s1[i] - 'a']++;
            hash_s2[s2[i] - 'a']++;
        }
        if(hash_s1 == hash_s2){  // O(1)
            return true;
        }
        // 滑动
        for(int i = s1_size; i < s2_size; i++){
            hash_s2[s2[i] - 'a']++;
            hash_s2[s2[i - s1_size] - 'a']--;
            if(hash_s1 == hash_s2){
                return true;
            }
        }
        return false;
    }
};
相关推荐
黄昏ivi1 小时前
电力系统最小惯性常数解析
算法
独家回忆3641 小时前
每日算法-250425
算法
烁3471 小时前
每日一题(小白)模拟娱乐篇33
java·开发语言·算法
Demons_kirit2 小时前
LeetCode 2799、2840题解
算法·leetcode·职场和发展
软行2 小时前
LeetCode 每日一题 2845. 统计趣味子数组的数目
数据结构·c++·算法·leetcode
永远在Debug的小殿下2 小时前
查找函数【C++】
数据结构·算法
我想进大厂2 小时前
图论---染色法(判断是否为二分图)
数据结构·c++·算法·深度优先·图论
油泼辣子多加2 小时前
【风控】稳定性指标PSI
人工智能·算法·金融
丰锋ff3 小时前
考研英一学习笔记
笔记·学习·考研
雾月553 小时前
LeetCode 1292 元素和小于等于阈值的正方形的最大边长
java·数据结构·算法·leetcode·职场和发展