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

一、题目描述

二、解题思路

整体思路

由于题目描述比较清晰,所以我们可以采用模拟的方法来解决这个问题。

具体思路

(1)首先,定义变量,ret数组作为最后的返回值,mod记录二进制前缀mod5的值,初始化为0;

(2)遍历nums数组:

<1>计算当前位置的mod值,执行Mod*=2,Mod+=nums[i],Mod%=5;

<2>将ret[i]赋值为!Mod,如果为0,就为true,反之就为false;

(3)nums遍历完成,ret更新完成,返回ret即为所求;

注意:在遍历数组的过程中需要计算当前二进制前缀是否为5的整数倍,我们不需要记录前缀的值,只需要记录前缀mod5的值就可,可以避免溢出。

三、代码实现

cpp 复制代码
class Solution {
public:
    vector<bool> prefixesDivBy5(vector<int>& nums) {
        int n=nums.size();
        vector<bool> ret(n,false);

        int Mod=0;
        for(int i=0;i!=n;i++){
            Mod*=2;
            Mod+=nums[i];
            Mod%=5;
            ret[i]=!Mod;
        }
        return ret;
    }
};
相关推荐
工口发动机22 分钟前
ABC440DEF简要题解
c++·算法
带土128 分钟前
4. C++ static关键字
开发语言·c++
橘颂TA29 分钟前
【Linux】死锁四条件的底层逻辑:从锁冲突到 STL 组件的线程安全实践(Ⅵ)
linux·运维·服务器·c++·死锁
C++ 老炮儿的技术栈35 分钟前
什么是通信规约
开发语言·数据结构·c++·windows·算法·安全·链表
零小陈上(shouhou6668889)1 小时前
K-近邻算法 - lazy learning的代表
算法·近邻算法
学历真的很重要1 小时前
LangChain V1.0 Context Engineering(上下文工程)详细指南
人工智能·后端·学习·语言模型·面试·职场和发展·langchain
有一个好名字1 小时前
力扣-从字符串中移除星号
java·算法·leetcode
萧瑟其中~1 小时前
二分算法模版——基础二分查找,左边界查找与右边界查找(Leetcode的二分查找、在排序数组中查找元素的第一个位置和最后一个位置)
数据结构·算法·leetcode
码上就好ovo1 小时前
Atcoder Beginnner Contest 440
算法