第 380 场 LeetCode 周赛题解

A 最大频率元素计数

模拟:先统计元素的频率,然后求由最大频率的元素的总频率

cpp 复制代码
class Solution {
public:
    int maxFrequencyElements(vector<int> &nums) {
        unordered_map<int, int> cnt;
        for (auto x: nums)
            cnt[x]++;
        int mx = 0, s = 0;
        for (auto [_, f]: cnt)
            if (f > mx) {
                mx = f;
                s = f;
            } else if (f == mx)
                s += f;
        return s;
    }
};

B 找出数组中的美丽下标 I

同t4...

cpp 复制代码
class Solution {
public:
    vector<int> beautifulIndices(string s, string a, string b, int k) {
        srand(time(0));//随机种子
        int e = 2333 + rand() % 100, mod = 1e9 + rand() % 100;
        shash hs(s, e, mod), ha(a, e, mod), hb(b, e, mod);
        vector<int> vi, vj;
        int ns = s.size(), na = a.size(), nb = b.size();
        for (int i = 0; i <= ns - na; i++)
            if (hs(i, i + na - 1) == ha(0, na - 1))
                vi.push_back(i);
        for (int j = 0; j <= ns - nb; j++)
            if (hs(j, j + nb - 1) == hb(0, nb - 1))
                vj.push_back(j);
        vector<int> res;
        for (auto i: vi) {
            auto l = lower_bound(vj.begin(), vj.end(), i - k);
            auto r = lower_bound(vj.begin(), vj.end(), i + k + 1);
            if (l != r)
                res.push_back(i);
        }
        return res;
    }

    class shash {//字符串哈希模板
    public:
        using ll = long long;
        vector<ll> pres;
        vector<ll> epow;
        ll e, p;

        shash(string &s, ll e, ll p) {
            int n = s.size();
            this->e = e;
            this->p = p;
            pres = vector<ll>(n + 1);
            epow = vector<ll>(n + 1);
            epow[0] = 1;
            for (int i = 0; i < n; i++) {
                pres[i + 1] = (pres[i] * e + s[i]) % p;
                epow[i + 1] = (epow[i] * e) % p;
            }
        }

        ll operator()(int l, int r) {
            ll res = (pres[r + 1] - pres[l] * epow[r - l + 1] % p) % p;
            return (res + p) % p;
        }
    };
};

C 价值和小于等于 K 的最大数字

二分 + 数学:通过二分枚举答案,这需要求不超过 m i d mid mid 的非负数( 0 0 0 的价值和为 0 0 0 不影响答案)的价值和,枚举二进制中的满足 i % x = = 0 i \% x == 0 i%x==0 的第 i i i 位, 0 ∼ m i d 0\sim mid 0∼mid 的第 i i i 位形成长为 2 i 2^i 2i 的循环数列的前 m i d + 1 mid+1 mid+1 项: 0 , ⋯   , 0 ⏟ 2 i − 1 个 0 , 1 , ⋯   , 1 ⏟ 2 i − 1 个 1 ⋯ \underset{2^{i-1}个0}{\underbrace{0,\cdots,0} } ,\underset{2^{i-1}个1}{\underbrace{1,\cdots,1} } \cdots 2i−1个0 0,⋯,0,2i−1个1 1,⋯,1⋯,所以可以直接求 0 ∼ m i d 0\sim mid 0∼mid 中第 i i i 位为 1 1 1 的数的数目

cpp 复制代码
class Solution {
public:
    using ll = long long;

    long long findMaximumNumber(long long k, int x) {
        ll l = 1, r = 1e15;
        while (l < r) {
            ll mid = (l + r + 1) / 2;
            ll s = 0;
            for (int i = 0; i < 50; i++)
                if ((i + 1) % x == 0) {
                    ll e = 1LL << (i + 1), se = 1LL << i;
                    ll c = (mid + 1) / e, mod = (mid + 1) % e;
                    s += c * se + (mod > se ? mod - se : 0);
                }
            if (s <= k)
                l = mid;
            else
                r = mid - 1;
        }
        return l;
    }
};

D 找出数组中的美丽下标 II

字符串哈希 + 二分:先用字符串哈希求出满足 0 ≤ i ≤ s . l e n g t h − a . l e n g t h 0 \le i \le s.length - a.length 0≤i≤s.length−a.length 和 s [ i , ( i + a . l e n g t h − 1 ) ] = a s[i,(i + a.length - 1)]=a s[i,(i+a.length−1)]=a 的 i i i 构成的有序数组 v i vi vi,和满足 0 ≤ j ≤ s . l e n g t h − b . l e n g t h 0 \le j \le s.length - b.length 0≤j≤s.length−b.length 和 s [ j , ( j + b . l e n g t h − 1 ) ] = b s[j,(j + b.length - 1)]=b s[j,(j+b.length−1)]=b 的 j j j 构成的有序数组 v j vj vj ,然后枚举 v i vi vi 中的 i i i ,在 v j vj vj 中二分查找 j ∈ [ i − k , i + k − 1 ) j\in [i-k,i+k-1) j∈[i−k,i+k−1) ,如果存在这样的 j j j ,则将 i i i 加入答案数组

cpp 复制代码
class Solution {
public:
    vector<int> beautifulIndices(string s, string a, string b, int k) {
        srand(time(0));//随机种子
        int e = 2333 + rand() % 100, mod = 1e9 + rand() % 100;
        shash hs(s, e, mod), ha(a, e, mod), hb(b, e, mod);
        vector<int> vi, vj;
        int ns = s.size(), na = a.size(), nb = b.size();
        for (int i = 0; i <= ns - na; i++)
            if (hs(i, i + na - 1) == ha(0, na - 1))
                vi.push_back(i);
        for (int j = 0; j <= ns - nb; j++)
            if (hs(j, j + nb - 1) == hb(0, nb - 1))
                vj.push_back(j);
        vector<int> res;
        for (auto i: vi) {
            auto l = lower_bound(vj.begin(), vj.end(), i - k);
            auto r = lower_bound(vj.begin(), vj.end(), i + k + 1);
            if (l != r)
                res.push_back(i);
        }
        return res;
    }

    class shash {//字符串哈希模板
    public:
        using ll = long long;
        vector<ll> pres;
        vector<ll> epow;
        ll e, p;

        shash(string &s, ll e, ll p) {
            int n = s.size();
            this->e = e;
            this->p = p;
            pres = vector<ll>(n + 1);
            epow = vector<ll>(n + 1);
            epow[0] = 1;
            for (int i = 0; i < n; i++) {
                pres[i + 1] = (pres[i] * e + s[i]) % p;
                epow[i + 1] = (epow[i] * e) % p;
            }
        }

        ll operator()(int l, int r) {
            ll res = (pres[r + 1] - pres[l] * epow[r - l + 1] % p) % p;
            return (res + p) % p;
        }
    };
};
相关推荐
Coovally AI模型快速验证36 分钟前
MMYOLO:打破单一模式限制,多模态目标检测的革命性突破!
人工智能·算法·yolo·目标检测·机器学习·计算机视觉·目标跟踪
可为测控1 小时前
图像处理基础(4):高斯滤波器详解
人工智能·算法·计算机视觉
Milk夜雨2 小时前
头歌实训作业 算法设计与分析-贪心算法(第3关:活动安排问题)
算法·贪心算法
BoBoo文睡不醒2 小时前
动态规划(DP)(细致讲解+例题分析)
算法·动态规划
apz_end3 小时前
埃氏算法C++实现: 快速输出质数( 素数 )
开发语言·c++·算法·埃氏算法
仟濹3 小时前
【贪心算法】洛谷P1106 - 删数问题
c语言·c++·算法·贪心算法
银河梦想家4 小时前
【Day23 LeetCode】贪心算法题
leetcode·贪心算法
CM莫问4 小时前
python实战(十五)——中文手写体数字图像CNN分类
人工智能·python·深度学习·算法·cnn·图像分类·手写体识别
sz66cm4 小时前
LeetCode刷题 -- 45.跳跃游戏 II
算法·leetcode
Amor风信子4 小时前
华为OD机试真题---战场索敌
java·开发语言·算法·华为od·华为