2024.3.7力扣每日一题——找出字符串的可整除数组

2024.3.7

      • 题目来源
      • 我的题解
        • [方法一 使用 BigInteger类(超时)](#方法一 使用 BigInteger类(超时))
        • [方法二 数学](#方法二 数学)

题目来源

力扣每日一题;题序:2575

我的题解

方法一 使用 BigInteger类(超时)

将字符串转换为BigInteger类

java 复制代码
import java.math.BigInteger;
class Solution {
    public int[] divisibilityArray(String word, int m) {
        int n=word.length();
        int[] res=new int[n];
        for(int i=1;i<=n;i++){
            BigInteger num=new BigInteger(word.substring(0,i));
            if(num.mod(BigInteger.valueOf(m)).equals(new BigInteger("0"))){
                res[i-1]=1;
            }
        }
        return res;
    }
}
方法二 数学

参考官方题解

一个整数可表示为 a×10+b:

(a×10+b) mod  m=(a mod  m×10+b) mod  m

所以可以按照上面的递推式,根据当前表示整数的余数,算出包含下一位字符所表示的整数的余数。

当余数为零时即为可整除数组,否则不是。最后返回结果即可。
时间复杂度:O(n)

空间复杂度:O(1)

java 复制代码
class Solution {
    public int[] divisibilityArray(String word, int m) {
        int[] res = new int[word.length()];
        long cur = 0;
        for (int i = 0; i < word.length(); i++) {
            char c = word.charAt(i);
            cur = (cur * 10 + (c - '0')) % m;
            res[i] = (cur == 0) ? 1 : 0;
        }
        return res;
    }
}

有任何问题,欢迎评论区交流,欢迎评论区提供其它解题思路(代码),也可以点个赞支持一下作者哈😄~

相关推荐
毕设源码-邱学长25 分钟前
【开题答辩全过程】以 基于Java企业人事工资管理系统为例,包含答辩的问题和答案
java·开发语言
转转技术团队28 分钟前
回收系统架构演进实战:与Cursor结对扫清系统混沌
java·架构·cursor
AI分享猿28 分钟前
Java后端实战:SpringBoot接口遇异常请求,轻量WAF兼顾安全与性能
java·spring boot·安全
稚辉君.MCA_P8_Java38 分钟前
Gemini永久会员 Java中的四边形不等式优化
java·后端·算法
DKPT1 小时前
ZGC和G1收集器相比哪个更好?
java·jvm·笔记·学习·spring
稚辉君.MCA_P8_Java1 小时前
通义 插入排序(Insertion Sort)
数据结构·后端·算法·架构·排序算法
n***F8751 小时前
修改表字段属性,SQL总结
java·数据库·sql
q***69771 小时前
【Spring Boot】统一数据返回
java·spring boot·后端
Hollis Chuang1 小时前
Spring Boot 4.0 正式发布,人麻了。。。
java·spring boot·后端·spring
Moshow郑锴1 小时前
实战分享:用 SpringBoot-API-Scheduler 构建 API 监控闭环 —— 从断言验证到智能警报
java·spring boot·后端·任务调度