leetcode 1018

1018: 可被5整除的二进制前缀

题意:计算 nums 每个前缀的二进制数值 x,判断 x 是否为 5 的倍数。

比如 nums=[1,1,0,1],每个前缀对应的二进制数分别为 1,11,110,1101。如何计算这些二进制数呢?在十进制中,我们往 12 的右边添加 3,得到 123,做法是 12⋅10+3=123。对于二进制,做法类似,往 110 的右边添加 1,得到 1101,做法是 110⋅2+1=1101,或者 110 << 1 ∣ 1=1101。

注意本题 nums 很长,算出的二进制数 x 很大,但我们只需要判断 xmod5=0 是否成立。可以在中途取模,也就是每次循环计算出新的 x 后,把 x 替换成 xmod5。为什么可以在中途取模?

**模运算对乘法和加法具有分配律,所以每一步更新时都可以先取模再运算,不影响最终模 5 的结果。**这样既节省了空间,又避免了超大整数问题。

复制代码
class Solution {
public:
    vector<bool> prefixesDivBy5(vector<int>& nums) {
        vector<bool> ans;
        int x=0;
        for(int i=0;i<nums.size();i++){
            x=(x<<1 | nums[i])%5;  //等价于x*2+nums[i]
            ans.push_back(x==0);
        }

        return ans;
    }
};
相关推荐
蓝色汪洋10 小时前
xtu oj矩阵
算法
hh随便起个名16 小时前
力扣二叉树的三种遍历
javascript·数据结构·算法·leetcode
Dingdangcat8617 小时前
城市交通多目标检测系统:YOLO11-MAN-FasterCGLU算法优化与实战应用_3
算法·目标检测·目标跟踪
tang&18 小时前
滑动窗口:双指针的优雅舞步,征服连续区间问题的利器
数据结构·算法·哈希算法·滑动窗口
拼命鼠鼠18 小时前
【算法】矩阵链乘法的动态规划算法
算法·矩阵·动态规划
LYFlied18 小时前
【每日算法】LeetCode 17. 电话号码的字母组合
前端·算法·leetcode·面试·职场和发展
式51619 小时前
线性代数(八)非齐次方程组的解的结构
线性代数·算法·机器学习
橘颂TA19 小时前
【剑斩OFFER】算法的暴力美学——翻转对
算法·排序算法·结构与算法
叠叠乐20 小时前
robot_state_publisher 参数
java·前端·算法
hweiyu0020 小时前
排序算法:冒泡排序
算法·排序算法