算法基础之计数问题

计数问题

  • 核心思想: 数位dp / 累加

累加

  • ​ 分情况讨论 :

      1. xxx = 000 ~ abc –1 yyy = 000 ~ 999 共 abc * 1000 种

        特别地,当枚举数字0时 (找第4位为0的数) 前三位不能从000开始了 否则没这个数不合法(有前导零)

      2. xxx == abc

        2.1. d < 1 , 不存在这样的数

        2.2. d == 1 , yyy = 000 ~ efg 共 efg + 1

        2.3. d > 1, yyy = 000 ~ 999 共1000种

      •   #include<iostream>using namespace std;typedef long long LL;int power10(int x)  //求10的x次方{int res = 1;while(x--) res *= 10;return res;}LL count(int n,int x)  // 求 1 ~ n 的x出现次数{LL res = 0;int l,r,cnt=0, m=n;while(m)  //求n的位数{cnt++;m /= 10;}for(int i=1;i<=cnt;i++)  //遍历每个位数{r = power10(i-1);  //求右半边的10的某次方l = n / (r * 10);  //求左半边的数if(x) res += l * r;  //x != 0else res += (l-1) * r;  // x == 0int d = (n / r) % 10;  // 求当前搜的的数if(d == x) res += (n % r) + 1;  //如果相等 是efg+1次else if (d > x) res += r;  //如果大于 是1000(10的某次方)}return res;}int main(){int a,b;while(cin>>a>>b , a||b){if(a>b) swap(a,b);  //保证大小顺序for(int i=0;i<10;i++)  //遍历0 ~ 9 每个数{cout<<count(b, i) - count(a-1 , i)<<" ";  //类似前缀和}cout<<endl;}return 0;}
        
    • 在这里插入图片描述

数位dp

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/590879.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

UnityShader(四)一个最简单的顶点/片元着色器

目录 顶点/片元着色器的基本结构&#xff1a; 简单的例子 增加模型数据 顶点着色器和片元着色器之间的通信 顶点/片元着色器的基本结构&#xff1a; Shader "MyShaderName"{Properties{//属性}SubShader{//针对显卡A的SubShaderPass{//设置渲染状态和标签//开始C…

C++正则表达式全攻略:从基础到高级应用

C正则表达式全攻略&#xff1a;从基础到高级应用 一、基础知识二、正则表达式的基本匹配三、C中使用正则表达式四、高级正则表达式五、实践示例六、性能优化6.1、编译正则表达式6.2、避免过度使用回溯6.3、优化匹配算法 七、总结 一、基础知识 正则表达式是一种用于匹配、搜索…

voronoi diagram

voronoi diagram Generalized voronoi diagram GVD Boris Lau - dynamicvoronoi 重要三篇论文链接 dynamic voronoi ros github dynamic voronoi 论文解读 - silver bullet - 慢悠悠的小马车 Voronoi-Based-Hybrid-Astar &#xff08;重要&#xff09; 重要论文 Local a…

ORACLE Primavera P6, Unifier v23.12 系统分享

引言 根据上周的计划&#xff0c;我近日简单制作了一个基于ORACLE Primavera P6 EPPM 以及Unifier 最新版23.12的虚拟机演示环境&#xff0c;里面包括了p6 和 unifier的全套系统服务 此虚拟系统环境仅用于演示、培训和测试目的。如要在生产环境中使用此虚拟机&#xff0c;请您…

设计模式在Java开发中的应用

设计模式在Java开发中起着至关重要的作用。它们是一些被广泛接受的、经过验证有效的解决问题的方法。设计模式可以帮助开发人员构建可维护、可扩展和易于理解的代码。在本文中&#xff0c;我将介绍一些在Java开发中常用的设计模式&#xff0c;并解释它们的应用场景和优点。 单例…

系列二、RestTemplate简介

一、RestTemplate简介 1.1、概述 RestTemplate是一种便捷的访问RestFul服务的模板类&#xff0c;是Spring提供的用于访问Rest服务的客户端模板工具集&#xff0c;它提供了多种便捷访问远程HTTP服务的方法。 1.2、API https://docs.spring.io/spring-framework/docs/5.2.2.REL…

mysqldump导出函数、存储过程和视图

mysqldump导出函数、存储过程和视图 导出函数和存储过程导出视图定义 导出函数和存储过程 查看函数和存储过程&#xff1a; select routine_schema,routine_name,routine_type from information_schema.routines where routine_schemaDBNAME and routine_type in (FUNCTIO…

从马尔可夫奖励过程到马尔可夫决策到强化学习【02/2】

一、说明 随着 Open AI 于 2023 年 11 月 6 日发布GPT 代理&#xff0c;我们所有人都对它带来的支持和灵活性着迷。想象一下&#xff0c;有一个个性化的数字助手始终在您身边&#xff0c;根据您的喜好完成日常平凡任务或艰巨任务。但为这些定制代理提供动力的是强化学习&#x…

【C语言】Windows上用GTK写GUI程序

要使用GTK开发一个Windows图形用户界面程序&#xff0c;需要首先设置GTK开发环境。这通常包括安装GTK库和它的依赖&#xff0c;以及配置编译器和工具链。可以选择使用纯C语言和GTK库或者使用支持GTK绑定的其他语言&#xff0c;如Python、C或Rust。 1. 安装GTK开发库 在Window…

Linux apt 命令

apt&#xff08;Advanced Packaging Tool&#xff09;是一个在 Debian 和 Ubuntu 中的 Shell 前端软件包管理器。 apt 命令提供了查找、安装、升级、删除某一个、一组甚至全部软件包的命令&#xff0c;而且命令简洁而又好记。 apt 命令执行需要超级管理员权限(root)。 apt 语…

Prototype原型模式(创建对象)

原型模式&#xff1a;Prototype 链接&#xff1a;原型模式实例代码 注解 模式定义 使用原型实例指定创建对象的种类&#xff0c;然后通过拷贝这些原型来创建新的对象。 ——《设计模式》GoF 目的 在软件系统中&#xff0c;经常面临这“某些结构复杂的对象”的创建工作&am…

Java ArrayList解密

数组的大小是固定的&#xff0c;一旦创建的时候指定了大小&#xff0c;就不能再调整了。也就是说&#xff0c;如果数组满了&#xff0c;就不能再添加任何元素了。 ArrayList 在数组的基础上实现了自动扩容&#xff0c;并且提供了比数组更丰富的预定义方法&#xff08;各种增删改…

pillow像型学操作(转载笔记) --- 西北乱跑娃

Opencv、Matplotlib(plt)、Pillow(PIL)、Pytorch读取数据的通道顺序 需注意:Pillow加载图像后的尺寸是二维,图形化是三维,但无法打印三维尺寸。 详细区别: Opencv:uint8的ndarray数据,通道顺序[h, w, c],颜色通道BGR。 导入模块:import cv2 (1)cv2.imread() (2)cv…

论文阅读: AAAI 2022行人重识别方向论文-PFD_Net

本篇博客用于记录一篇行人重识别方向的论文所提出的优化方法《Pose-Guided Feature Disentangling for Occluded Person Re-identification Based on Transformer》&#xff0c;论文中提出的PDF_Net模型的backbone是采用《TransReID: Transformer-based Object Re-Identificati…

探寻最短路径之谜:Dijkstra算法详解

探寻最短路径之谜&#xff1a;Dijkstra算法详解 大家好&#xff0c;我是免费搭建查券返利机器人赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天&#xff0c;让我们一起深入研究一项在图论领域中备受推崇的算法…

YHZ014 Python 算术运算符

&#x1f989; 运算符 资源编号&#xff1a;YHZ014 配套视频&#xff1a;https://www.bilibili.com/video/BV1zy4y1Z7nk?p15 &#x1f578;️ 算术运算符 以下假设变量 a10&#xff0c;变量 b21&#xff1a; 运算符描述实例加 - 两个对象相加a b 输出结果 31-减 - 得到负数…

【AI】人工智能爆发推进器之迁移学习

目录 一、什么是迁移学习 二、迁移学习和VAE 三、迁移学习的分类 3.1 按迁移内容分类&#xff1a; 3.2 按迁移方法分类&#xff1a; 3.3 按学习形式分类&#xff1a; 3.4 按目标域有无标签分类&#xff1a; 3.5 按学习方法分类&#xff1a; 3.6 按特征分类&#xff1a…

vue常见属性

vue实例的属性 data 用于设置和绑定的字段 data() {return{plan: ,planlist: []} },methods 用来设置方法&#xff0c;绑定对应的按钮或者事件 <button v-on:click“addPlan”>添加任务 methods: {addPlan() {if(this.plan null || this.plan ){return}this.planlist.…

TypeScript 之 interface 和 type 的区别

结论&#xff1a; 1、可以声明的数据类型 type 可以修饰任何类型 &#xff08;值类型和引用数据类型&#xff09; interface 只能修饰引用类型 &#xff08;对象、数组、函数&#xff09; //interface 声明对象属性 interface ins {a: string;b?: number; //可选项 }// int…

HackTheBox - Medium - Linux - Encoding

Encoding 前言 经过10个月左右的网安自学&#xff0c;我想说的第一句话无疑是&#xff1a;感谢TryHackMe。当然&#xff0c;后续的HackTheBox&学院、CRTO等等&#xff0c;对我的帮助都很大。 许多师傅们都在年度总结&#xff0c;我也看了大家都收获很多&#xff0c;都很…