【Leetcode】第 378 场周赛

文章目录

  • [100166. 检查按位或是否存在尾随零](#100166. 检查按位或是否存在尾随零)
  • [100185. 找出出现至少三次的最长特殊子字符串 I](#100185. 找出出现至少三次的最长特殊子字符串 I)
  • [100184. 找出出现至少三次的最长特殊子字符串 II](#100184. 找出出现至少三次的最长特殊子字符串 II)

100166. 检查按位或是否存在尾随零

题目

题意

这里题目要求的是或运算,所以原数组中只需要有两个或者两个以上的数字是满足存在一个尾随零条件即可

代码

c++ 复制代码
class Solution {
public:
    bool hasTrailingZeros(vector<int>& nums) {
        int n=nums.size();
        int ans=0;
        for(int i=0;i<n;++i)
            if(nums[i]%2==0)ans++;
        if(ans>=2)return true;
        return false;
    }
};

100185. 找出出现至少三次的最长特殊子字符串 I

题目

思路

这个问题可以通过先统计字符串中相同字母的连续出现长度,然后按长度从大到小排序。接下来,按照规则处理这些长度。

从最长的特殊子串中取三个长度均为 (a[0] - 2) 的特殊子串。

从最长和次长的特殊子串中取三个长度一样的特殊子串:

如果 a[0] = a[1],取三个长度均为 (a[0] - 1) 的特殊子串。

如果 a[0] > a[1],取三个长度均为 a[1] 的特殊子串:从最长中取两个,从次长中取一个。

即为 min(a[0] - 1, a[1])。

从最长、次长、第三长的特殊子串中各取一个长为 a[2] 的特殊子串。

这三种情况取最大值,即为 max(a[0] - 2, min(a[0] - 1, a[1]), a[2])。

最后,取每一组的最大值,即为答案。如果答案是 0,返回 -1。

代码

c++ 复制代码
class Solution {
public:
    int maximumLength(string s) {
        vector<int> charGroups[26];
        int counter = 0, length = s.length();
        for (int i = 0; i < length; i++) {
            counter++;
            if (i + 1 == length || s[i] != s[i + 1]) {
                charGroups[s[i] - 'a'].push_back(counter);
                counter = 0;
            }
        }
        int result = 0;
        for (auto &group: charGroups) {
            if (group.empty()) continue;
            sort(group.rbegin(), group.rend());
            group.push_back(0);
            group.push_back(0); // 假设还有两个空串
            result = max({result, group[0] - 2, min(group[0] - 1, group[1]), group[2]});
        }
        return result ? result : -1;
    }
};

100184. 找出出现至少三次的最长特殊子字符串 II

做法同上

相关推荐
搬砖的小码农_Sky2 分钟前
比特币区块链:SHA256哈希函数
算法·区块链·哈希算法
CSCN新手听安10 分钟前
【Qt】系统相关(二)鼠标事件的处理,鼠标的按下,释放,双击,移动,滚轮滚动事件的处理
开发语言·c++·qt
承渊政道11 分钟前
【动态规划算法】(一文讲透二维费用的背包问题)
数据结构·c++·学习·算法·leetcode·动态规划·哈希算法
2301_8152795219 分钟前
鸿蒙原生开发的“硬核通道”:ArkTS 与 C/C++ 高性能互操作全栈指南 —— FFI 机制深度解析与实战精要
c语言·c++·harmonyos
Zevalin爱灰灰6 小时前
现代密码学 第二章——流密码【下】
算法·密码学
飞Link8 小时前
大模型长文本的“救命稻草”:深度解析 TurboQuant 与 KV Cache 压缩技术
算法
郝学胜-神的一滴9 小时前
深度学习优化核心:梯度下降与网络训练全解析
数据结构·人工智能·python·深度学习·算法·机器学习
Je1lyfish9 小时前
CMU15-445 (2025 Fall/2026 Spring) Project#3 - QueryExecution
linux·c语言·开发语言·数据结构·数据库·c++·算法
许彰午10 小时前
03-二叉树——从递归遍历到非递归实现
java·算法
Brilliantwxx10 小时前
【C++】 vector(代码实现+坑点讲解)
开发语言·c++·笔记·算法