Codeforces Round 952 (Div. 4) G. D-Function 题解 数学 数论

D-Function

题目描述

Let D ( n ) D(n) D(n) represent the sum of digits of n n n. For how many integers n n n where 1 0 l ≤ n < 1 0 r 10^{l} \leq n < 10^{r} 10ln<10r satisfy D ( k ⋅ n ) = k ⋅ D ( n ) D(k \cdot n) = k \cdot D(n) D(kn)=kD(n)? Output the answer modulo 1 0 9 + 7 10^9+7 109+7.

输入描述

The first line contains an integer t t t ( 1 ≤ t ≤ 1 0 4 1 \leq t \leq 10^4 1t104) – the number of test cases.

Each test case contains three integers l l l, r r r, and k k k ( 0 ≤ l < r ≤ 1 0 9 0 \leq l < r \leq 10^9 0l<r109, 1 ≤ k ≤ 1 0 9 1 \leq k \leq 10^9 1k109).

输出描述

For each test case, output an integer, the answer, modulo 1 0 9 + 7 10^9 + 7 109+7.

提示

For the first test case, the only values of n n n that satisfy the condition are 1 1 1 and 2 2 2.

For the second test case, the only values of n n n that satisfy the condition are 1 1 1, 10 10 10, and 11 11 11.

For the third test case, all values of n n n between 10 10 10 inclusive and 100 100 100 exclusive satisfy the condition.

题面翻译

D ( n ) D(n) D(n) 代表 n n n 各个数位上数字之和。求:有多少个 n n n 满足 1 0 l ≤ n < 1 0 r 10^{l} \leq n < 10^{r} 10ln<10r D ( k ⋅ n ) = k ⋅ D ( n ) D(k \cdot n) = k \cdot D(n) D(kn)=kD(n)?答案对 1 0 9 + 7 10^9+7 109+7 取模。

样例 #1

样例输入 #1

6
0 1 4
0 2 7
1 2 1
1 2 3
582 74663 3
0 3 1

样例输出 #1

2
3
90
12
974995667
999

原题

Codeforces——传送门
洛谷——传送门

思路

对于 D ( k ⋅ n ) = k ⋅ D ( n ) D(k \cdot n) = k \cdot D(n) D(kn)=kD(n)我们观察可以得到 左式一定小于等于右式。因为右式是对每一位数字都乘以 k k k 再相加,左式对 n n n 中每一位数字乘以 k k k 后要先处理进位再相加,而每发生一次进位都会导致最后得到的和少了 10 10 10。所以如果要满足 D ( k ⋅ n ) = k ⋅ D ( n ) D(k \cdot n) = k \cdot D(n) D(kn)=kD(n),则 k k k 乘以每一位都不能 ≥ 10 ≥10 10,即对于 n n n 中的任意一位数字 x x x,需满足 x ∗ k ≤ 9 x*k≤9 xk9

因为 x ∗ k ≤ 9 x*k≤9 xk9,所以对于 n n n 的每一位,若该位为最高位,则 x x x 不能为 0 0 0,可满足的位数字有 k 9 \frac{k}{9} 9k 种;若该位不为最高位,则可满足的位数字有 k 9 + 1 \frac{k}{9}+1 9k+1 种。因此对于 1 0 i ≤ n < 1 0 i + 1 10^{i}≤n<10^{i+1} 10in<10i+1,满足条件的 n n n 的个数有 k 9 ∗ ( k 9 + 1 ) i \frac{k}{9}*(\frac{k}{9}+1)^{i} 9k(9k+1)i 个。那么答案就是 k 9 ∗ ( k 9 + 1 ) r − 1 − k 9 ∗ ( k 9 + 1 ) l − 1 \frac{k}{9}*(\frac{k}{9}+1)^{r-1}-\frac{k}{9}*(\frac{k}{9}+1)^{l-1} 9k(9k+1)r19k(9k+1)l1,利用等比数列求和公式化简得 ( k 9 + 1 ) r − ( k 9 + 1 ) l (\frac{k}{9}+1)^{r}-(\frac{k}{9}+1)^{l} (9k+1)r(9k+1)l当然也可以不化简直接计算结果。

代码

#include <bits/stdc++.h>
using namespace std;
using i64 = long long;const i64 mod = 1e9 + 7;
// 快速幂
i64 qpow(i64 a, i64 b, i64 c)
{i64 ans = 1;a %= c;while (b){if (b & 1){ans = (ans * a) % c;}a = (a * a) % c;b >>= 1;}return ans % c;
}int main()
{ios::sync_with_stdio(0);cin.tie(0);int t;cin >> t;while (t--){i64 l, r, k;cin >> l >> r >> k;i64 num = 9 / k + 1;cout << (qpow(num, r, mod) - qpow(num, l, mod) + mod) % mod << '\n';}return 0;
}

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

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

相关文章

mybatisplus新增数据时生成的雪花id太长前端接收不准确怎么办?

这是后端返回的&#xff1a;1807308955001573377 这是前端接收的&#xff1a;1807308955001573400 返回的long类型超过前端的最大长度了&#xff0c;渲染不了 只需要在WebMvcConfiguration配置类中重写方法&#xff0c;如下 Overrideprotected void configureMessageConver…

深度学习:C++和Python如何对大图进行小目标检测

最近在医美和工业两条线来回穿梭&#xff0c;甚是疲倦&#xff0c;一会儿搞搞医美的人像美容&#xff0c;一会儿搞搞工业的检测&#xff0c;最近新接的一个项目&#xff0c;关于瑕疵检测的&#xff0c;目标图像也并不是很大吧&#xff0c;需要放大后&#xff0c;才能看见细小的…

基于Java的跨平台移动应用开发

基于Java的跨平台移动应用开发 大家好&#xff0c;我是免费搭建查券返利机器人省钱赚佣金就用微赚淘客系统3.0的小编&#xff0c;也是冬天不穿秋裤&#xff0c;天冷也要风度的程序猿&#xff01;今天我们将探讨基于Java的跨平台移动应用开发&#xff0c;这是一种强大的技术方案…

使用 App Store Connect API 生成和读取分析报告

文章目录 前言安装 API Swift SDK配置 API Swift SDK生成分析报告获取所有可用的报告获取报告的分段下载分段的数据总结 前言 Apple 最近推出了50多个新的分析报告&#xff0c;其中包含数百个新的数据点和指标&#xff0c;以帮助开发者了解他们的应用程序的表现情况。 这些报…

构建安全稳定的应用:Spring Security 实用指南

前言 在现代 Web 应用程序中&#xff0c;安全性是至关重要的一个方面。Spring Security 作为一个功能强大且广泛使用的安全框架&#xff0c;为 Java 应用程序提供了全面的安全解决方案。本文将深入介绍 Spring Security 的基本概念、核心功能以及如何在应用程序中使用它来实现…

相比共享代理,为什么要用独享代理IP?

随着互联网的广泛普及和应用&#xff0c;涉及网络隐私、数据安全和网络访问控制的问题变得越来越重要。代理服务器作为一种常见的网络工具&#xff0c;可以在跨境电商、海外社媒、SEO投放、网页抓取等领域发挥作用&#xff0c;实现匿名访问并加强网络安全。在代理服务器类别中&…

Hadoop:全面深入解析

Hadoop是一个用于大规模数据处理的开源框架&#xff0c;其设计旨在通过集群的方式进行分布式存储和计算。本篇博文将从Hadoop的定义、架构、原理、应用场景以及常见命令等多个方面进行详细探讨&#xff0c;帮助读者全面深入地了解Hadoop。 1. Hadoop的定义 1.1 什么是Hadoop …

CDC模型

引言 聚类是一种强大的机器学习方法&#xff0c;用于根据特征空间中元素的接近程度发现相似的模式。它广泛用于计算机科学、生物科学、地球科学和经济学。尽管已经开发了最先进的基于分区和基于连接的聚类方法&#xff0c;但数据中的弱连接性和异构密度阻碍了其有效性。在这项…

Linux 下的性能监控与分析技巧

在日常的服务器管理和问题诊断过程中&#xff0c;Linux 命令行工具提供了强大的支持。本文通过几个常用的示例&#xff0c;介绍如何快速定位问题、监控服务器性能。 无论你是编程新手还是有一定经验的开发者&#xff0c;理解和掌握这些命令&#xff0c;都将在你的工作中大放异…

第四篇——作战篇:战争里的激励与成本

目录 一、背景介绍二、思路&方案三、过程1.思维导图2.文章中经典的句子理解3.学习之后对于投资市场的理解4.通过这篇文章结合我知道的东西我能想到什么&#xff1f; 四、总结五、升华 一、背景介绍 前面进行了分析之后&#xff0c;这篇显然又从经济的角度进行了介绍和分析…

STELLA系统动态模拟技术及在农业、生态及环境等科学领域中的应用技术

STELLA是一种用户友好的计算机软件。通过绘画出一个系统的形象图形&#xff0c;并给这个系统提供数学公式和输入数据&#xff0c;从而建立模型。依据专业兴趣&#xff0c;STELLA可以用来建立各种各样的农业、生态、环境等方面的系统动态模型&#xff0c;为科研、教学、管理服务…

用例子和代码了解词嵌入和位置编码

1.嵌入&#xff08;Input Embedding&#xff09; 让我用一个更具体的例子来解释输入嵌入&#xff08;Input Embedding&#xff09;。 背景 假设我们有一个非常小的词汇表&#xff0c;其中包含以下 5 个词&#xff1a; "I""love""machine"&qu…

10 Posix API与网络协议栈

POSIX概念 POSIX是由IEEE指定的一系列标准,用于澄清和统一Unix-y操作系统提供的应用程序编程接口(以及辅助问题,如命令行shell实用程序),当您编写程序以依赖POSIX标准时,您可以非常肯定能够轻松地将它们移植到大量的Unix衍生产品系列中(包括Linux,但不限于此!)。 如…

DeepFaceLive----AI换脸简单使用

非常强大的软件,官方github https://github.com/iperov/DeepFaceLive 百度云链接: 链接&#xff1a;https://pan.baidu.com/s/1VHY-wxqJXSh5lCn1c4whZg 提取码&#xff1a;nhev 1下载解压软件 下载完成后双击.exe文件进行解压.完成后双击.bat文件打开软件 2 视频使用图片换…

k8s部署单机版mysql8

一、创建命名空间 # cat mysql8-namespace.yaml apiVersion: v1 kind: Namespace metadata:name: mysql8labels:name: mysql8# kubectl apply -f mysql8-namespace.yaml namespace/mysql8 created# kubectl get ns|grep mysql8 mysql8 Active 8s二、创建mysql配…

Ubuntu环境下Graphics drawString 中文乱码解决方法

问题描述 以下代码在,在本地测试时 ,可以正常输出中文字符的图片,但部署到线上时中文乱码 // 获取Graphics2D对象以支持更多绘图功能 Graphics2D g2d combined.createGraphics(); // 示例字体、样式和大小 Font font new Font("微软雅黑", Font.PLAI…

Swagger:swagger和knife4j

Swagger 一个规范完整的框架 用以生成,描述,调用和可视化 主要作用为 自动生成接口文档 方便后端开发进行接口调试 Knife4j 为Java MVC框架集成 依赖引入: <!-- knife4j版接口文档 访问/doc.html--> <dependency><groupId>com.github.xiaoymin<…

SSM学习4:spring整合mybatis、spring整合Junit

spring整合mybatis 之前的内容是有service层&#xff08;业务实现层&#xff09;、dao层&#xff08;操作数据库&#xff09;&#xff0c;现在新添加一个domain&#xff08;与业务相关的实体类&#xff09; 依赖配置 pom.xml <?xml version"1.0" encoding&quo…

解决ScaleBox来实现大屏自适应时,页面的饼图会变形的问题

封装一个公用组件pieChartAdaptation.vue 代码如下&#xff1a; <template><div :style"styleObject" class"pie-chart-adaptation"><slot></slot></div> </template><script setup lang"ts"> impo…

2.2.3 C#中显示控件BDPictureBox 的实现----控件实现

2.2.3 C#中显示控件BDPictureBox 的实现----控件实现 1 界面控件布局 2图片内存Mat类说明 原始图片&#xff1a;m_raw_mat ,Display_Mat()调用时更新或者InitDisplay_Mat时更新局部放大显示图片&#xff1a;m_extract_zoom_mat&#xff0c;更新scale和scroll信息后更新overla…