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;
    }
};
相关推荐
苏宸啊13 分钟前
C++string(一)
开发语言·c++
uoKent33 分钟前
c++中的封装、继承与多态
开发语言·c++·算法
踏过山河,踏过海43 分钟前
vs2019报错:Failed to connect to VCTIP: ‘CreateFile‘ failed with 2
c++
Sheep Shaun1 小时前
C++11核心特性详解:从右值引用到现代C++编程
开发语言·数据结构·c++·算法
小王努力学编程1 小时前
LangChain——AI应用开发框架
服务器·c++·人工智能·分布式·rpc·langchain·brpc
呱呱巨基1 小时前
Linux Ext系列文件系统
linux·c++·笔记·学习
云深麋鹿1 小时前
三.栈和队列
开发语言·数据结构·c++·算法
爆打维c2 小时前
01BFS算法(例题:网格传送门旅游)
c语言·c++·python·算法·leetcode·广度优先
像素猎人2 小时前
力扣:面试题16.01.交换数字
c++·算法·leetcode·面试
CSDN_RTKLIB2 小时前
C++仿函数
c++·算法·stl