hdu3652(数位dp)

要求找出范围内含有“13”且能被13整除的数字的个数

可以使用数位dp

dp[i][j][0] 表示长度为i,余数为j,不含13的数字的个数

dp[i][j][1] 表示长度为i,余数为j,3开头的数字的个数

dp[i][j][2] 表示长度为i,余数为j,含有"13"的数字的个数

index[1] = 1;

for(i=2; i<11; ++i)

  index[i] = (index[i-1] * 10) % 13;

index[i] 存储的为1,10,100,1000,10000 % 13 的余数

那么,状态转移方程详见源代码

 1 #include <stdio.h>
 2 int dp[11][13][3];
 3 int index[11];
 4 int num[11];
 5 void init()
 6 {
 7     int i,j,k;
 8     index[1] = 1;
 9     for(i=2; i<11; ++i)
10         index[i] = (index[i-1]*10) % 13;
11     dp[0][0][0] = 1;
12     for(i=1; i<11; ++i)
13     {
14         for(k=0; k<13; ++k)
15         {
16             //(1)
17             dp[i][(index[i]+k)%13][0] -= dp[i-1][k][1];
18             //长度为i-1,余数为k的不含13的数字前面加上3,-->长度为i-1,余数为k的3开头的个数
19             dp[i][(index[i]*3+k)%13][1] += dp[i-1][k][0];
20             //长度为i-1,余数为k的3开头的数字前面加上1-->长度为i,余数为(index[i]+k)%13含13的数字个数
21             dp[i][(index[i]+k)%13][2] += dp[i-1][k][1];
22             for(j=0; j<10; ++j)
23             {
24                 //长度为i-1,余数为k的不含13的数字前面加上j-->长度为i,余数为(index[i]*j+k)%13不含13的数字个数
25                 //但是dp[i-1][k][0] 里面是包含dp[i-1][k][1]的,当加上数字1时,成为了含有13的数字,这里多加,所以在(1)处减去
26                 dp[i][(index[i]*j+k)%13][0] += dp[i-1][k][0];
27                 //长度为i-1,余数为k的含13的数字前面加上j-->长度为i,余数为(index[i]*j+k)%13含13的数字个数
28                 dp[i][(index[i]*j+k)%13][2] += dp[i-1][k][2];
29             }
30         }
31     }
32 }
33 int getAns(int n)
34 {
35     int i,j,k,len=0,ans=0;
36     while(n)
37     {
38         num[++len] = n % 10;
39         n /= 10;
40     }
41     num[len+1] = 0;
42     bool flag = false;
43     int t = 0,mod;
44     for(i=len; i>=1; --i)
45     {
46         for(k=0; k<13; ++k)
47         {
48             if(num[i]>1 && !flag)//第i位取1
49             {
50                 mod = (index[i]+k+t)%13;//第i位取1时余数为mod
51                 if(mod==0) ans += dp[i-1][k][1];//如果余数为0,那么就加上3开头的数字个数
52             }
53             if(num[i+1]==1 && num[i]>3 &&!flag)//第i+1位为1,第i位取3.
54             {
55                 mod = (t + k) % 13;//第i+1位为1,第i位取3的余数为mod
56                 if(mod==0) ans += dp[i][k][1];//如果余数为0,那么就加上3开头的数字个数
57             }
58             for(j=0; j<num[i]; ++j)//第i位为j时,
59             {
60                 mod = (index[i]*j+k+t)%13;//第i位为j时余数为mod
61                 if(mod==0) ans += dp[i-1][k][2];//如果余数为0,那么就加上含有13的数字的个数
62                 if(mod==0 && flag) ans += dp[i-1][k][0];//如果余数为0,且前面的数字含有13,那么就加上不含13的数字个数
63             }
64         }
65         t = (t + num[i]*index[i])%13;//第len位到第i位的数字固定后产生的余数
66         if(num[i+1]==1 && num[i]==3)
67             flag = true;
68     }
69     return ans;
70 }
71 int main()
72 {
73     int n;
74     init();
75     
76     while(scanf("%d",&n)!=EOF)
77     {
78         printf("%d\n",getAns(n+1));
79     }
80     return 0;
81 }
View Code

数位dp的难点就在于状态的转移,还有统计。

关键要弄懂它统计的原理。

http://www.cnblogs.com/justPassBy/p/4275226.html

转载于:https://www.cnblogs.com/justPassBy/p/4277263.html

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

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

相关文章

怎么查看电脑是不是禁ping_怎么查看电脑内存的大小,找回丢失的内存,电脑小技巧...

小A自己组装了一台电脑&#xff0c;配件都是在jd买了。他高高兴兴的安装了系统准备开始体验一把&#xff0c;同事突然问&#xff0c;你的电脑内存是多少&#xff0c;他点来点去也没找到答案。他只知道他买了一个8G的内存条。.我们一般查看内存有两个地方。一我们的电脑 属性 安…

finereport字段显示设置_QA | 表单如何设置字段显示逻辑?

Hi&#xff0c;大家好&#xff01;表姐又来给大家答疑解惑啦&#xff01;这一期的Q&A我们来聊聊表单如何设置字段显示逻辑。字段显示逻辑是什么&#xff1f;字段显示逻辑是指根据设定字段条件&#xff0c;显示或隐藏特定的字段&#xff0c;可以实现选择不同内容&#xff0c…

数据库管理之数据表管理(1)

数据类型 创建数据表 语法 CREATE TABLE 表名 ( 字段名1 数据类型 列的属性 列约束, 字段名2 数据类型 列的属性 列约束, 字段名3 数据类型 列的属性 列约束, … )列属性的格式&#xff1a; [NULL|NOT NULL] [IDENTITY(标识种子, 标识增量)]列约束的格式&#xff1a; [CONST…

AngularJs-指令和指令之间的交互(动感超人)

前言&#xff1a; 上节我们学习到了指令和控制器之间的交互&#xff0c;通过给指令添加动作&#xff0c;调用了控制器中的方法。本节我们学习指令和指令之间是如何交互的&#xff0c;我们通过一个小游戏来和大家一起学习&#xff0c;听大漠老师说这是国外的人写的demo&#xff…

vba 指定列后插入列_在不同的列左侧插入指定数量的空白列

任务: 在不同的列左侧插入指定数量的空白列(本例是要求在每列左侧插入第2行数字对应的空白列) 插入空白列前 插入空白列后 vba代码如下&#xff1a; Sub 在不同的列左侧插入指定数量的空白列() Dim m, n, i As Integer For n 5 To 1 Step -1 Sheets("Sheet1").C…

怎么监听linux防火墙,linux怎么查看防火墙是否开启并清除防火墙规则?

iptables是linux下的防火墙组件服务&#xff0c;相对于windows防火墙而言拥有更加强大的功能&#xff0c;下面我们就来看看linux系统中关于iptables的一般常见操作&#xff0c;判断linux系统是否启用了iptables服务&#xff0c;并清除防火墙规则的教程。一、检查iptables是否安…

手册如何看运放的db_如何处理金属离子与配体之间的配位键?

更多资讯&#xff0c;请访问www.yinfotek.com 或关注微信公众号“殷赋科技”。殷赋学术交流2群已建立&#xff0c;需求加群的朋友&#xff0c;请在公众号输入“加群”&#xff0c;验证后即入群。1A:请教大家一个问题&#xff1a;在做对接模拟的过程中蛋白活性中心存在重要金属离…

secure连不上远程地址_[笔记]Mariadb安装并配置远程访问

引言熟悉的小伙伴都知道我自用有一台NAS&#xff0c;并为此折腾了不少内容&#xff1a;西蒙宫&#xff1a;折腾&#xff0c;用J3455搭建家庭nas西蒙宫&#xff1a;让家庭NAS走向世界&#xff0c;兼谈Zerotier西蒙宫&#xff1a;折腾——组装NAS编译安装ffmpeg在NAS上部署了Next…

从Wireshark看TCP连接的建立与关闭

TCP是一种面向连接、可靠的协议。TCP连接的建立与断开&#xff0c;都是需要经过通信双方的协商。用一句话概括就是&#xff1a;三次握手say hello&#xff08;建立连接&#xff09;&#xff1b;四次握手say goodbye&#xff08;断开连接&#xff09;。要了解TCP连接的建立与断开…

用Visual C#来清空回收站(2)

四.程序的源代码&#xff08;recycled.cs&#xff09;、编译方法及运行后的界面&#xff1a;  &#xff08;1&#xff09;.程序的源代码&#xff1a;recycled.cs&#xff1a; using System.IO ; using System.Windows.Forms ; //导入程序中用到的名称空间 class Recycle { pu…

jq苹果手机全屏下点击无效果_苹果系统自带外挂?无需越狱也可录制动作脚本...

网络游戏开始流行起来之后&#xff0c;随之而来的是外挂的兴起&#xff0c;各式各样的外挂中有两种最为致命&#xff1a;物理外挂和系统自带外挂。随着国内电竞行业和电竞直播的兴起&#xff0c;“物理外挂”出现在我们周围的频率也越来越高&#xff0c;比如扩大视角的显示器、…

c语言不同类型变量用什么表示什么作用,C语言数据类型及变量整理

数据类型获取int的字节数大小方法printf("int bytes:%d",sizeof(int));列表整理Int 与 long int的区别早期的C平台是16位int系统&#xff0c;int用二字节表示&#xff0c;范围是-32768~32767&#xff1b;long是long int的简写&#xff0c;用4字节表示&#xff0c;范围…

通知:即日起本博客暂停更新,请移步至yanxin8.com获取最新文章

通知&#xff1a;即日起本博客暂停更新&#xff0c;请移步至yanxin8.com与博主交流及获取最新文章 转载于:https://www.cnblogs.com/iplus/p/4467089.html

通信系统概论_现代通信系统概论 第一章 概述(1)

2020年&#xff0c;又开始上一门新课&#xff01;&#xff01;&#xff01;喜欢挑战&#xff01;让同学们开阔知识是本课程的主要目的&#xff01;本课程讲解导航、遥控遥测等军用尖端技术和数字电话、广播电视、综合信息网、多媒体宽带网等现代民用技术。通信在过去分为模拟通…

安装CentOS6.2操作系统

原创作品&#xff0c;出自 “深蓝的blog” 博客&#xff0c;欢迎转载&#xff0c;转载时请务必注明出处&#xff0c;否则追究版权法律责任。 深蓝的blog&#xff1a;http://blog.csdn.net/huangyanlong/article/details/40131523 说明&#xff1a;因为之前有相关安装文章能够查…

在用c语言写代码是这么找出错误,写代码(C语言)常见粗心小错误

打码(C语言)常见粗心小错误标签(空格分隔)&#xff1a; 博客自我介绍本人学院 (http://sdcs.sysu.edu.cn/) 欢迎访问本人学号 16340213目录##1.前言小萌新们是不是经常打完码之发现程序运行达不到自己的效果&#xff0c;然后自己用大脑运行的时候发现完全没有问题&#xff0c;然…

Analyzer报表结果行

隐藏结果&#xff08;统计&#xff09;行 &#xff08;注&#xff1a;在Analyzer设置只是临时起作用&#xff0c;如果要使设置一直生效&#xff0c;则要通过Query Designer进行设置&#xff09; 显示多个值&#xff1a;如果结果只是由一条记录汇总得来的&#xff0c;则在该列上…

jeecg输入中文查询导表为空_简单查询

语法1.sql以 ; 结尾2.sql不区分关键字大小写3.输入符号时候只能使用英文4.列名不加引号基本查询语句1. select 列名,列名from 表名;2. select *from 表名;3. select 列名 as 列名重命名, 列名 as 列名重命名2from 表名;4. select distinct 列名from 表名;注意事项&#xff1a; …

USACO Section 4.2 Drainage Ditches(最大流)

最大流问题。ISAP算法。注意可能会有重边&#xff0c;不过我用的数据结构支持重边。距离d我直接初始化为0&#xff0c;也可以用BFS逆向找一次。-----------------------------------------------------------------------#include<cstdio>#include<iostream>#inclu…

gtb分类器参数调节_集成学习

About个人同时在简书和自制个人博客两个地方同时更新文章&#xff0c;有兴趣的话可以来我的博客玩呀&#xff0c;一般而言排版会好不少。本篇在博客的位置。集成学习一句话版本集成学习的思想是将若干个学习器(分类器&回归器)组合之后产生新的学习器。在学习这一章节中&…