C++ | Leetcode C++题解之第233题数字1的个数

题目:

题解:

cpp 复制代码
class Solution {
public:
    int countDigitOne(int n) {
        // mulk 表示 10^k
        // 在下面的代码中,可以发现 k 并没有被直接使用到(都是使用 10^k)
        // 但为了让代码看起来更加直观,这里保留了 k
        long long mulk = 1;
        int ans = 0;
        for (int k = 0; n >= mulk; ++k) {
            ans += (n / (mulk * 10)) * mulk + min(max(n % (mulk * 10) - mulk + 1, 0LL), mulk);
            mulk *= 10;
        }
        return ans;
    }
};
相关推荐
誰能久伴不乏5 小时前
【Qt实战】工业级多线程串口通信:从底层协议设计到完美收发闭环
linux·c++·qt
2401_832131955 小时前
模板错误消息优化
开发语言·c++·算法
金枪不摆鳍5 小时前
算法--二叉搜索树
数据结构·c++·算法
liu****5 小时前
4.Qt窗口开发全解析:菜单栏、工具栏、状态栏及对话框实战
数据库·c++·qt·系统架构
近津薪荼5 小时前
优选算法——双指针6(单调性)
c++·学习·算法
helloworldandy5 小时前
高性能图像处理库
开发语言·c++·算法
2401_836563185 小时前
C++中的枚举类高级用法
开发语言·c++·算法
EmbedLinX6 小时前
C++ 面向对象
开发语言·c++
weixin_445402306 小时前
C++中的命令模式变体
开发语言·c++·算法
Hgfdsaqwr6 小时前
实时控制系统优化
开发语言·c++·算法