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;
    }
};
相关推荐
如竟没有火炬4 分钟前
四数相加贰——哈希表
数据结构·python·算法·leetcode·散列表
Simon席玉19 分钟前
C++的命名重整
开发语言·c++·华为·harmonyos·arkts
仰泳的熊猫19 分钟前
1148 Werewolf - Simple Version
数据结构·c++·算法·pat考试
十五年专注C++开发25 分钟前
同一线程有两个boost::asio::io_context可以吗?
c++·boost·asio·异步编程·io_context
xlq223221 小时前
26 avl树(下)
c++
郝学胜-神的一滴1 小时前
深入理解OpenGL VBO:原理、封装与性能优化
c++·程序人生·性能优化·图形渲染
埃伊蟹黄面1 小时前
模拟算法思想
c++·算法·leetcode
小老鼠不吃猫1 小时前
深入浅出(六)序列化库 FlatBuffers、Protobuf、MessagePack
c++·开源·buffer
Unlyrical1 小时前
Valgrind快速使用
c++·valgrind
李余博睿(新疆)2 小时前
c++练习题-双分支
c++