当前位置: 首页 > article >正文

Leetcode 3448. Count Substrings Divisible By Last Digit

  • Leetcode 3448. Count Substrings Divisible By Last Digit
    • 1. 解题思路
    • 2. 代码实现
  • 题目链接:3448. Count Substrings Divisible By Last Digit

1. 解题思路

这一题的话我们走的是一个累积数组的思路。

首先,我们使用一个cache数组记录下任意段数字对 1 1 1 9 9 9的余数,即任意cache[i][j] = int(s[:i]) % j

然后,我们考察任意位置上所有前序数组对 1 1 1 9 9 9的余数,即 ∑ j = 0 i s j i ≡ m o d ( k ) \sum\limits_{j=0}^{i}s_{ji} \equiv mod(k) j=0isjimod(k),而要求上述问题,我们可以反向求累积数组 ∑ j = 0 i ( s i − s j × 1 0 i − j ) ≡ m o d ( k ) \sum\limits_{j=0}^{i}(s_{i} -s_{j} \times 10^{i-j}) \equiv mod(k) j=0i(sisj×10ij)mod(k)

因此,我们可以用累计数组进行求解。

2. 代码实现

给出python代码实现如下:

class Solution:
    def countSubstrings(self, s: str) -> int:
        n = len(s)
        cache = [[0 for _ in range(10)] for _ in range(n)]
        mod = [0 for _ in range(10)]
        for i, ch in enumerate(s):
            digit = int(ch)
            for j in range(1, 10):
                mod[j] = (mod[j] * 10 + digit) % j
                cache[i][j] = mod[j]
        
        def update_cnt(cnt):
            ans = [[0 for j in range(i)] for i in range(10)]
            for i in range(1, 10):
                for j in range(i):
                    r = (j * 10) % i
                    ans[i][r] += cnt[i][j]
            return ans
        
        ans = 0
        cnt = [[0 for j in range(i)] for i in range(10)]
        for i in range(1, 10):
            cnt[i][0] += 1
        for i, ch in enumerate(s):
            cnt = update_cnt(cnt)
            digit = int(ch) 
            
            if digit != 0:
                ans += cnt[digit][cache[i][digit]]
                
            for j in range(1, 10):
                cnt[j][cache[i][j]] += 1
                
        return ans

提交代码评测得到:耗时9031ms,占用内存38.3MB。

需要注意的是,事实上上述代码还可以进一步优化,因为至少1,2,5几个数是必然满足只要以对应的数字结尾就一定可以满足条件,因此,我们事实上是可以对上述算法进行优化的,不过这里就不过多展开了,有兴趣的读者可以自行尝试一下。


http://www.kler.cn/a/542668.html

相关文章:

  • 物联网(IoT)如何与人工智能(AI)的结合
  • 【图片合并转换PDF】如何将每个文件夹下的图片转化成PDF并合并成一个文件?下面基于C++的方式教你实现
  • python-leetcode-单词搜索
  • IntelliJ IDEA Console控制台输出成json的配置方式
  • 深入解析 Kafka 消费者偏移量管理
  • 修复缺失的tobii.gameintegration.dll文件,让游戏更顺畅
  • 更新无忧:用 Docker 数据卷确保 Open WebUI 数据持久化
  • java项目部署到linux读取properties中文乱码
  • 超全前端面试(全!全!全!!!)
  • LeetCode 每日一题 2025/2/3-2025/2/9
  • 2024.1.2版本Android Studio gradle下载超时问题处理
  • python基础入门:6.2JSON与CSV数据处理
  • SkyWalking 10.1.0 实战:从零构建全链路监控,解锁微服务性能优化新境界
  • qt QCommandLineOption 详解
  • 蓝桥杯算法日记|2.11二分算法
  • 【目标检测xml2json】label从VOC格式xml文件转COCO格式json文件
  • PostgreSQL 数据库压力测试指南
  • 普通用户授权docker使用权限
  • docker和docker compose版本太低问题的解决方案
  • 16.React学习笔记.React更新机制
  • 大模型被偷家?CNN结合多模态!
  • 2025.2.11——一、[极客大挑战 2019]PHP wakeup绕过|备份文件|代码审计
  • 前端设计模式介绍及案例(单例模式、代理模式、工厂模式、装饰者模式、观察者模式)
  • SpringBoot 统一功能处理之拦截器、数据返回格式、异常处理
  • clone gerrit repos 到windows本地
  • 算法设计-归并排序(C++)