力扣每日一题:能被k整除的最小整数

给定正整数 k ,你需要找出可以被 k 整除的、仅包含数字 1 的最 正整数 n 的长度。

返回 n 的长度。如果不存在这样的 n ,就返回-1。

注意: n 可能不符合 64 位带符号整数。

思路:

本题主要借用了余数的一些定理。即:

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

(a*b) mod m = ((a mod m)*(b mod m)) mod m

因此,可以得到一个结论,当遇到相同的余数时,则表示不存在这样的n。

下面我将说明这个结论怎么得到的:

假设有m1个1和有m2个1,余数一致(m1<m2)。

则可以得到(m2-m1) mod k=((m2 mod k)-(m1 mod k)) mod k=0.因为m1和m2 mod k相同。

此时观察m2-m1的组成:(m2-m1)个1,和m1个0组成,也就是(m2-m1)个1,乘以m1个10.

观察这时候的m1*10。假如10 mod k不为0,则表示m1 mod k等于0或者m2-m1个1 mod k等于0,则在获得m2之前,就已经有了答案。

假如10 mod k为0,则k必定含有因数5或2。但是任何由全1构成的数字,一定不含有结尾0,一定不能被5或2整除,因此此时一定可以确定无解。

综上,要么在获得m2之前,就有了需要的结果。要么,获得m2,此时可以明确无解。

复制代码
class Solution {
public:
    int smallestRepunitDivByK(int k) {
         
        unordered_set<int>st;
        int num=1,count=1;
        while(!st.count(num)&&num%k)
        {   
            st.insert(num);
            num=num*10+1;
            num%=k;
            count++;
        }
        if(st.count(num))return -1;
        return count;
    }
};
相关推荐
Q741_14723 分钟前
每日一题 力扣 3655. 区间乘法查询后的异或 II 模拟 分治 乘法差分法 快速幂 C++ 题解
c++·算法·leetcode·模拟·快速幂·分治·差分法
The_Ticker24 分钟前
印度股票实时行情API(低成本方案)
python·websocket·算法·金融·区块链
夏乌_Wx28 分钟前
剑指offer | 2.4数据结构相关题目
数据结构·c++·算法·剑指offer·c/c++
AI成长日志1 小时前
【笔面试算法学习专栏】哈希表基础:两数之和与字母异位词分组
学习·算法·面试
minji...1 小时前
Linux 线程同步与互斥(二) 线程同步,条件变量,pthread_cond_init/wait/signal/broadcast
linux·运维·开发语言·jvm·数据结构·c++
abant21 小时前
leetcode 239 单调队列 需要一些记忆
算法·leetcode·职场和发展
漫霂2 小时前
二叉树的统一迭代遍历
java·算法
炽烈小老头2 小时前
【每天学习一点算法 2026/04/08】阶乘后的零
学习·算法
Mr_Xuhhh2 小时前
算法刷题笔记:从滑动窗口到哈夫曼编码,我的算法进阶之路
开发语言·算法
游乐码2 小时前
C#Queue
数据结构·游戏·c#