首页 > 编程语言 >C++数位算法:数字1的个数

C++数位算法:数字1的个数

时间:2023-10-24 16:02:47浏览次数:43  
标签:string int iRet 个数 iMul C++ len vCurOneNum 数位


题目

给定一个整数 n,计算所有小于等于 n 的非负整数中数字 1 出现的个数。
示例 1:
输入:n = 13
输出:6
示例 2:
输入:n = 0
输出:0
提示:
0 <= n <= 109

2023年1月版

class Solution {
 public:
 int countDigitOne(int n) {
 int iNum = 0;
 int iMul = 1;
 for (int i = 0; i < 9; i++)
 {
 iNum += n / (iMul * 10) *iMul;
 int tmp = n % (iMul * 10);
 if (tmp >= iMul)
 {
 if (tmp >= iMul * 2)
 {
 tmp = iMul * 2 - 1;
 }
 iNum += tmp - (iMul - 1);
 }
 iMul *= 10;
 }
 if (1000 * 1000 * 1000 == n)
 {
 iNum++;
 }
 return iNum;
 }
 };

2023年8月 数位

class CTest : public CLowUperr<char,int,‘0’,‘9’>
 {
 public:
 CTest():CLowUperr(10)
 {
 }
 // 通过 CLowUperr 继承
 virtual void OnDo(vector<vector>& dp, int preStatus, int curStatus, int cur) override
 {
 dp[curStatus][cur] += m_vPreCan[preStatus];
 m_vCurOneNum[curStatus] += m_vPreOneNum[preStatus];
 }
 virtual void OnInitDP(vector<vector>& dp)
 {
 for (int i = 0; i < 4; i++)
 {
 m_vPreCan[i] = std::accumulate(MACRO_BEGIN_END(m_vPre[i]), 0);
 m_vPreOneNum[i] = m_vCurOneNum[i] + m_vPre[i][1];
 }
 memset(m_vCurOneNum, 0, sizeof(m_vCurOneNum));
 }
 int Total()
 {
 int iRet = 0;
 for (int i = 0; i < 4; i++) 
 { 
 iRet += m_vCurOneNum[i] + m_vPre[i][1];
 }
 return iRet;
 }
 int m_vPreCan[4] = { 0 };//前四中状态的可能
 int m_vPreOneNum[4] = { 0 };//前面4种状态1的数量
 int m_vCurOneNum[4] = { 0 };//前面4种状态1的数量};
class Solution {
 public:
 int countDigitOne(int n) {
 string str = std::to_string(n); 
 int len = 1;
 for (; len < str.length(); len++)
 {
 Do(“1” + string(len - 1, ‘0’), string(len, ‘9’));
 }
 Do(“1” + string(len - 1, ‘0’), str);
 return m_iRet;
 }
 void Do(string s1, string s2)
 {
 CTest test;
 test.Init(s1.data(), s2.data(), s1.length());
 m_iRet += test.Total();
 }
 int m_iRet;
 };

扩展阅读


相关下载

想高屋建瓴的学习算法,请下载《闻缺陷则喜算法册》doc版

鄙人想对大家说的话

闻缺陷则喜是一个美好的愿望,早发现问题,早修改问题,给老板节约钱。

墨家名称的来源:有所得以墨记

之。 |
|如果程序是一条龙,那算法就是他的是睛|

测试环境

操作系统:win7 开发环境: VS2019 C++17
或者 操作系统:win10 开发环境: VS2022 C++17

C++数位算法:数字1的个数_c++


标签:string,int,iRet,个数,iMul,C++,len,vCurOneNum,数位
From: https://blog.51cto.com/u_15724537/8005225

相关文章

  • C++桶排序算法的应用:存在重复元素 III
    题目给你一个整数数组nums和两个整数indexDiff和valueDiff。找出满足下述条件的下标对(i,j):i!=j,abs(i-j)<=indexDiffabs(nums[i]-nums[j])<=valueDiff如果存在,返回true;否则,返回false。示例1:输入:nums=[1,2,3,1],indexDiff=3,valueDiff=0输出......
  • C++前缀和算法应用:矩形区域不超过 K 的最大数值和
    题目给你一个mxn的矩阵matrix和一个整数k,找出并返回矩阵内部矩形区域的不超过k的最大数值和。题目数据保证总会存在一个数值和不超过k的矩形区域。示例1:输入:matrix=[[1,0,1],[0,-2,3]],k=2输出:2解释:蓝色边框圈出来的矩形区域[[0,1],[-2,3]]的数值和是......
  • 时间复杂度O(40n*n)的C++算法:修改图中的边权
    1.12.1.题目给你一个n个节点的无向带权连通图,节点编号为0到n-1,再给你一个整数数组edges,其中edges[i]=[ai,bi,wi]表示节点ai和bi之间有一条边权为wi的边。部分边的边权为-1(wi=-1),其他边的边权都为正数(wi>0)。你需要将所有边权为-1的边都修改为范......
  • 在C++中,互斥变量(std::mutex)是用于保护共享资源的重要工具,但它们确实有一些局限性,其中
    在C++中,互斥变量(std::mutex)是用于保护共享资源的重要工具,但它们确实有一些局限性,其中之一是无法保证包含指针的区域的多线程安全。这是因为互斥锁本质上只能保护它们所保护的代码块,而不会考虑指针指向的数据。下面是一些与互斥锁和指针相关的常见问题和注意事项:共享数据的复制:......
  • C++_Cmake的使用
    C++系统版本、软件依赖版本、组件LSB(全称:LinuxStandardsBase)LSBsharedobjectELF是ExecutableLinkableFormat的缩写,是Linux的链接、可执行、共享库的格式标准,COFF:CommonObjectCOFF(通用对象文件格式) 编译器:简单构建gcc编译流程分为4个步骤,分......
  • C++初识(续篇)
    1.2注释作用:在代码中加一些说明和解释,方便自己或其他程序员阅读代码两中格式单行注释:通常放在一行代码的上方,或者一条语句的末尾,对该行代码说明//这样的是单行注释多行注释:通常放在一段代码的上方,对该段代码做整体说明/*这种的是多行注释可以写好多行*/......
  • c++中的宏#define用途
    宏的一些作用,包括但不限于这些定义一个变量、字符串、类型定义一个函数、条件表达式条件编译、调试信息,异常类定义结构体、命名空间定义模版、枚举、函数对象#define宏定义在C++中用于定义常量、函数、条件编译、字符串、条件表达式、变量、注释、调试信息、类型、函数等,下面是一些......
  • C++的编译链接与在vs中build提速
    通过gcc或msvc,clang等编译器编译出来的C++源文件是.o文件。在windows上也就是PE文件,linux为ELF文件,在这一步中,调用其它代码文件中的函数的函数地址是未知的(00000),等到链接之后才会替换掉函数地址的linux,windows可执行文件(ELF、PE)C++是如何编译的C/C++编译过程主要分为4个过程......
  • C++常用语法知识--数据类型
    C++常用语法知识--数据类型C++为用户提供了7种基本C++数据类型:类型关键字字节大小布尔型bool1字符型char1有符号字符型signedchar1无符号字符型unsignedchar1整型int4有符号整型signedint4无符号整型unsignedint4短整型int2......
  • C++常用语法知识-- std::istringstream
    C++常用语法知识--std::istringstream介绍std::istringstream是C++标准库中的一个类,它用于从字符串中提取数据,并将数据转换为不同的数据类型。通常从字符串中解析数据,例如整数、浮点数等。使用方法创建std::istringstream对象,首先,需要创建一个std::istringstream对象,将......