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;
    }
};
相关推荐
想唱rap8 分钟前
C++之红黑树
开发语言·数据结构·c++·算法
无限进步_9 分钟前
C++运算符重载完全指南:从基础到实战应用
开发语言·数据库·c++·windows·git·github·visual studio
sin_hielo15 分钟前
leetcode 3623
算法·leetcode·哈希算法
feiyangqingyun30 分钟前
Qt/C++地图最简示例/在线离线切换/地图视图切换/执行各种js函数交互
javascript·c++·qt
暗然而日章1 小时前
C++基础:Stanford CS106L学习笔记 4 容器(STL与序列容器)
c++·笔记·学习
系夏普1 小时前
重拾 C++:Ubuntu开发环境下的C++学习
c++
kk”1 小时前
C++ AVL树
开发语言·数据结构·c++
西幻凌云1 小时前
认识STLstack容器
c++·stl·适配器·stack·序列式容器
繁华似锦respect1 小时前
C++ 设计模式之观察者模式详细介绍
linux·开发语言·c++·windows·观察者模式·设计模式·visual studio
威桑1 小时前
一个 CMake 项目是否只能有一个 install 目录?
linux·c++·cmake