Divide by Zero 2021 and Codeforces Round #714 (Div. 2) C. Add One

news2025/1/24 8:40:25

 Problem - C - Codeforces

翻译:

给你一个整数𝑛。您必须对其应用𝑚操作。

在单个操作中,必须将该数字的每个数字𝑑替换为整数𝑑+1的十进制表示形式。例如,在应用一次操作后,1912变成21023。

在应用𝑚操作后,必须找到𝑛的长度。因为答案可以很大,对109+7取模打印。

输入
第一行包含一个整数𝑡(1≤𝑡≤2⋅105)——测试用例的数量。

每个测试用例的唯一一行包含两个整数𝑛(1≤𝑛≤109)和𝑚(1≤𝑚≤2⋅105)——初始数和操作数。

输出
对于每个测试用例,输出结果数对109+7模的长度。

例子
inputCopy
5
1912年1
5个6
999年1
88 2
100年12
outputCopy
5
2
6
4
2115
请注意
对于第一个测试,1912在1个长度为5的操作后变成21023。

对于第二个测试,5在6次操作后变成21,长度为2。

对于第三个测试,999在经过1个长度为6的操作后变成101010。

对于第四个测试,88经过两次运算后变成1010,长度为4。

思路:

就是操作m次,然后每次给每个数字加上1,数据范围挺小,开了个数组直接去暴力想着也就m*10的复杂度,忘了还有个T,这道题没有给总数的范围限制,所以无脑只会T。后来仔细想了一下,只有9+1才会变成两位数字10,0 1 2 3 4 5 6 7 8这些数字变化不会增加位数,只有达到9+1,才会对答案有贡献,所以我们直接对9预处理出来2e5次操作的情况,其余数字就是减去其到9的操作,然后再统计,这样的话只需要预处理一个数字即可。

之后我们统计给的数字个数,然后直接求和即可。

嗲吗:

#include <iostream>
#include <algorithm>
#include <string.h>
#include <string>
#include <math.h>
#include <stdio.h>
#include<vector>
#include<queue>
#include<map>
#include<set>
#include<tuple>
#include<numeric>
#include<stack>
using namespace::std;
typedef long long  ll;
int n,t;
inline __int128 read(){
    __int128 x = 0, f = 1;
    char ch = getchar();
    while(ch < '0' || ch > '9'){
        if(ch == '-')
            f = -1;
        ch = getchar();
    }
    while(ch >= '0' && ch <= '9'){
        x = x * 10 + ch - '0';
        ch = getchar();
    }
    return x * f;
}
inline void print(__int128 x){
    if(x < 0){
        putchar('-');
        x = -x;
    }
    if(x > 9)
        print(x / 10);
    putchar(x % 10 + '0');
}
const ll N=1e9+7;
ll an,m;
ll ff[10];
ll yuc[200005];
void solv(){
    for (int i =0; i<10; i++) {
        ff[i]=0;
    }
    cin>>an>>m;
    while (an>0) {
        ff[an%10]++;
        an/=10;
    }
    
//    for (int i =0; i<m; i++) {
//        for (int  j= 9; j>=1; j--) {
//            swap(ff[j],ff[j-1]);
//            ff[j]%=N;
//        }
//        ff[1]=(ff[1]+ff[0])%N;
//        ff[0]%=N;
//    }
    ll ans=0;
    for (int i =0; i<=9; i++) {
        if (9-i>=m) {
            ans=(ans+ff[i])%N;
        }
        else{
            ans=(ans+yuc[m-(9-i)]*ff[i])%N;
        }
    }
    
    printf("%lld\n",ans);
}
int main(){
    ios::sync_with_stdio(false);
    cin.tie(); cout.tie();
    yuc[0]=1;
    ff[9]=1;
    for (int i =1; i<200001; i++) {
        for (int  j= 9; j>=1; j--) {
            swap(ff[j],ff[j-1]);
            ff[j]%=N;
            yuc[i]=(yuc[i]+ff[j])%N;
        }
        ff[1]=(ff[1]+ff[0])%N;
        ff[0]%=N;
        yuc[i]=(yuc[i]+ff[0]*2)%N;
    }
//    for (int i =0; i<=100; i++) {
//        printf("i::%d %lld\n",i,yuc[i]);
//    }
    cin>>t;
    while (t--) {
        solv();
    }
    return 0;
}
 

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

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

相关文章

安利一个Python大数据分析神器!

对于Pandas运行速度的提升方法&#xff0c;之前已经介绍过很多回了&#xff0c;里面经常提及Dask&#xff0c;很多朋友没接触过可能不太了解&#xff0c;今天就推荐一下这个神器。 1、什么是Dask&#xff1f; Pandas和Numpy大家都不陌生了&#xff0c;代码运行后数据都加载到…

项目里接入了MQ消息中间件以后,我摸鱼的时间更长了~

V-xin&#xff1a;ruyuanhadeng获得600页原创精品文章汇总PDF 一、前情回顾 之前给大家聊了一下&#xff0c;面试时如果遇到消息中间件这个话题&#xff0c;面试官上来可能问的两个问题&#xff1a; 你们的系统架构中为什么要引入消息中间件&#xff1f;系统架构中引入消息中…

零跑汽车股价终于盼来了期望

近期零跑股价上涨&#xff0c;给其它汽车产业带来了危机。9月29日&#xff0c;零跑汽车作为第四位登陆港股的新势力车企&#xff0c;终于胜利敲钟。但是&#xff0c;紧接着等待零跑的却是刷新新势力纪录的开盘破发。 继开盘首日暴跌33%之后&#xff0c;9月30日收盘&#xff0c;…

Linux权限---用户权限切换与文件权限更改(附目录,哪里不懂点哪里)--- 第一期

目录 1. Linux权限的概念 1.1 什么是权限 1.2 所以权限的操作一共分为两类 1.3 Linux中&#xff0c;默认有两类用户 2. root与普通用户切换指令 2.1 如果想从普通用户转为超级用户可以进行下面操作 2.2 如果想从超级用户转为普通用户可以进行下面操作 2.3 禁止来回切换用…

阿里技术官耗时半年总结出“满分”架构笔记,拿捏分布式到微服务

第 1 章&#xff1a;深入理解网络 讲解分布式的基础一-网络&#xff0c; 对国际互联网、NIO、AIO、网络传输中的对象序列化问题、HTTP 的前世今生、TCP/IP、从 CDN 到 SD-WAN 等知识进行深入讲解。 详细章节介绍&#xff1a; 从国际互联网开始 NIO, 一本难念的经 AIO,大道至…

Redis 非关系型数据库

关系型数据库与非关系型数据库 Redis支持的键值数据类型 Redis中文网 2. 哈希类型 hash 删除&#xff1a;hdel key field 3. 列表类型 list:可以添加一个元素到列表的头部&#xff08;左边&#xff09;或者尾部&#xff08;右边&#xff09; 列表类型相当于队列 4. 集合…

Vue--》vue-router的导航守卫使用讲解

目录 前言 vue-router中编程式导航API 导航守卫 全局守卫 独享路由守卫 组件路由守卫 前言 在浏览器中点击链接实现导航的方式&#xff0c;叫做声明式导航。例如&#xff1a;普通网页中点击<a>链接、vue项目中点击<router-link>都属于声明式导航。 在浏览器…

0基础转软件测试该学些什么?

有很多人员会不断问自己&#xff0c;自己到底要不要学测试&#xff0c;或者要不要转行做测试&#xff0c;测试的职业发展到底怎么样&#xff1f;如果你还在迷茫&#xff0c;在到处找各种大牛问类似的问题&#xff0c;我希望这篇文章&#xff0c;你看完能够结束你的这个烦恼&…

从 0 到 1 搞一个 Compose Desktop 版本的玩天气之踩坑

从 0 到 1 搞一个 Compose Desktop 版本的玩天气之踩坑 大家好&#xff0c;好久不见&#xff0c;接下来一段时间我会系统性地写一套关于 Compose Desktop 的文章&#xff0c;带大家从头到尾写一个桌面版的天气应用&#xff0c;并且打好包让别人也可以进行使用&#xff0c;接下…

java判断选择的日期是否在某个时间区间

效果展示&#xff1a; 具体代码&#xff1a; String startTimeZoom "08:00";//时间区间-开始时间 String endTimeZoom "22:00";//时间区间-结束时间String startTimeChoice "08:00";//时间区间-选择的开始时间 String endTimeChoice "2…

Java中的异常(Exception)

目录 一、什么是异常(Exception)&#xff1f; 二、解决方案&#xff1a;try-catch 三、异常的概念 四、异常的体系图(重点) 小结&#xff1a; 五、常见的五大运行时异常 1、NullPointerException空指针异常 2、ArithmeticException数学运算异常 3、ArrayIndexOutOfBounds…

【MySQL进阶】浅谈InnoDB中的BufferPool

【MySQL进阶】浅谈InnoDB中的BufferPool 文章目录【MySQL进阶】浅谈InnoDB中的BufferPool一、前言——缓存的重要性二、InnoDB的Buffer Pool1&#xff1a;BufferPool 简介2&#xff1a;BufferPool内部组成3&#xff1a;free链表的管理4&#xff1a;flush链表的管理5&#xff1a…

PCA与PCoA

通过分析坐标轴中样本和样本间的距离可看到 2 个样本或 2 组样本间的差异性。若2个样本或2组样本之间的直线距离较近&#xff0c;则表示这2个样本或2组样本差异性较小&#xff1b;相反则表示差异性较大。因此PCA和PCoA 具有直观性(直接看两点之间的距离)和完整性(呈现所有样本)…

spring中i18n国际化处理多语言

前言 在项目中&#xff0c;往往用户会存在多语言的述求&#xff0c;比如说一个系统既有中文的用户&#xff0c;又有英文的用户。怎么来实现多语言呢&#xff1f; 首先前后端分离的项目&#xff0c;前端会有自己的多语言实现方案&#xff0c;大致效果就是&#xff0c;用户切换…

rocketmq源码-pull模式拉取消息、同步拉取消息

前言 上一篇博客&#xff0c;记录的是push模式&#xff0c;异步发送netty请求拉取消息的代码&#xff0c;这篇博客主要记录consumer发送同步netty请求&#xff0c;去拉取消息的逻辑&#xff0c;但是对于同步发送请求&#xff0c;需要结合LitePullConsumer来看 在Lite PullCon…

C语言基础—运算符及优先级

本章主要讲解运算符的优先级和结合顺序 知识点&#xff1a; 运算符分类&#xff0c;记忆了解13种运算符注意运算符的易错点运算符的优先级 运算符及优先级运算符分类❗ 运算符易错不能直接连续判断“< 值 <”关于判断两个浮点数是否相等逻辑表达式&#xff08;布尔型&am…

CSS:border-image

border-image属性对图像的规格和比例比较高&#xff0c;导致使用成本比较高。另外&#xff0c;常见的场景中&#xff0c;大家更倾向于扁平化而不是非拟物化&#xff0c;边框装饰通常在项目中不会出现。 border-image是由多个CSS属性缩写的&#xff0c;比如: border-image-sou…

hc32和stm32 can波特率设置

前言 笔者在调试一款新的mcu的can通信时候&#xff0c;最麻烦的是波特率设置。由于没有弄明白其计算原理&#xff0c;经常出错&#xff0c;且不同的波特率有不同的采样点的要求。浪费了不少时间。这次一次搞明白can波特率的计算公式。 can波特率计算 在ISO 11898-1-2015 标准…

音视频基础概念(2)——音频

目录 1. 基本知识 2.采样率和采样位数 3.音频编码 4. 声道数 5. 码率 6. 音频格式 日常生活中&#xff0c;音视频随处可见&#xff0c;包括视频、音频、编解码、封装容器、音视频等概念。 1. 基本知识 音频数据的承载方式最常用的是脉冲编码调制&#xff0c;即PCM。于…

JAVA面试(2022年Java常见面试问题)

1、谈谈你对Spring中IOC和AOP的理解。 答案&#xff1a; 2、谈谈Spring的bean的创建过程和生命周期。 答案&#xff1a; 3、谈一下JVM的内存分配和垃圾回收机制。 答案&#xff1a; 4、谈一下你使用比较多的设计模式和场景。 答案&#xff1a; 5、谈一些mysql的事务隔离。 …