P2188 小Z的 k 紧凑数

题目描述

小 Z 在草稿纸上列出了很多数,他觉得相邻两位数字差的绝对值不超过 k 的整数特别奇特,称其为 k 紧凑数。

现在小 Z 想知道 [l,r] 内有多少个 k 紧凑数,希望你帮帮他。

输入输出格式

输入格式:

第一行包含三个整数 l,r,k。

输出格式:

第一行包含一个整数,表示 [l,r] 内 k 紧凑数的个数。

输入输出样例

输入样例#1:

  1. 1 13 1
输出样例#1:

  1. 12

说明

【数据规模】

对于 30% 的数据,r − l ≤ 10^5;

对于另外 30% 的数据,l = 1,r 为 10 的倍数;

对于 100% 的数据,1 ≤ l ≤ r ≤ 10^18,0 ≤ k ≤ 8。

  1. #include<iostream>
  2. #include<cstdio>
  3. using namespace std;
  4. long long l,r;
  5. int k,len,bin[],b[];
  6. long long dfs(int pos,int pre,int limit,int lead){
  7. if(pos==len+)return ;
  8. int end=limit?bin[pos]:;
  9. long long ans=;
  10. if(pos==){
  11. for(int i=;i<=end;i++)
  12. ans+=dfs(pos+,i,limit&&i==end,lead&&i==);
  13. }
  14. else if(lead){
  15. for(int i=;i<=end;i++)
  16. ans+=dfs(pos+,i,limit&&i==end,lead&&i==);
  17. }
  18. else{
  19. for(int i=max(,pre-k);i<=min(pre+k,end);i++)
  20. ans+=dfs(pos+,i,limit&&i==end,lead&&i==);
  21. }
  22. return ans;
  23. }
  24. long long work(long long x){
  25. len=;
  26. while(x){
  27. b[++len]=x%;
  28. x/=;
  29. }
  30. for(int i=,j=len;i<=len;i++,j--)bin[i]=b[j];
  31. return dfs(,,,);
  32. }
  33. int main(){
  34. freopen("Cola.txt","r",stdin);
  35. scanf("%d%d%d",&l,&r,&k);
  36. cout<<work(r)-work(l-);
  37. }

30分 暴力枚举数的每一位

  1. #include<cstdio>
  2. #include<cstring>
  3. #include<iostream>
  4. #include<cmath>
  5. #include<cstdlib>
  6. #define int long long
  7. using namespace std;
  8. int f[][],x,y,m,bin[];
  9. int dp(int x){
  10. if(x==)return ;
  11. bin[]=;while(x)bin[++bin[]]=x%,x/=;
  12. if(bin[]==)return bin[]+;
  13. int ans=;
  14. for(int i=;i<bin[];i++)
  15. for(int j=;j<;j++)ans+=f[i][j];
  16. for(int i=;i<bin[bin[]];i++)ans+=f[bin[]][i];
  17. for(int i=bin[]-;i;i--){
  18. if(i<bin[]-&&abs(bin[i+]-bin[i+])>m)return ans;
  19. for(int j=;j<bin[i];j++)if(abs(j-bin[i+])<=m)ans+=f[i][j];
  20. }
  21. if(abs(bin[]-bin[])<=m)ans++;return ans;
  22. }
  23. signed main(){
  24. freopen("Cola.txt","r",stdin);
  25. cin>>x>>y>>m;
  26. for(int i=;i<;i++)f[][i]=;
  27. for(int i=;i<=;i++)
  28. for(int j=;j<;j++)
  29. for(int k=;k<;k++)if(abs(j-k)<=m)f[i][j]+=f[i-][k];
  30. cout<<dp(y)-dp(x-);
  31. return ;
  32. }

100分 数位dp

洛谷P2188 小Z的 k 紧凑数的更多相关文章

  1. P2188 小Z的 k 紧凑数 题解(数位DP)

    题目链接 小Z的 k 紧凑数 解题思路 数位DP,把每一个数位的每一个数对应的可能性表示出来,然后求\(num(1,r)-num(1,l-1)\),其中\(num(i,j)\)表示\([i,j]\)区 ...

  2. Bzoj2038/洛谷P1494 小Z的袜子(莫队)

    题面 Bzoj 洛谷 题解 考虑莫队算法,首先对询问进行分块(分块大小为\(sqrt(n)\)),对于同一个块内的询问,按照左端点为第一关键字,右端点为第二关键字排序.我们统计这个区间内相同的颜色有多 ...

  3. 洛谷 2186 小Z的栈函数

    https://www.luogu.org/problem/show?pid=2186 题目描述 小Z最近发现了一个神奇的机器,这个机器的所有操作都是通过维护一个栈来完成的,它支持如下11个操作: N ...

  4. 洛谷——P2117 小Z的矩阵

    P2117 小Z的矩阵 题目描述 小Z最近迷上了矩阵,他定义了一个对于一种特殊矩阵的特征函数G.对于N*N的矩阵A,A的所有元素均为0或1,则G(A)等于所有A[i][j]*A[j][i]的和对2取余 ...

  5. 洛谷—— P2117 小Z的矩阵

    https://www.luogu.org/problemnew/show/2117 题目描述 小Z最近迷上了矩阵,他定义了一个对于一种特殊矩阵的特征函数G.对于N*N的矩阵A,A的所有元素均为0或1 ...

  6. 洛谷 P2117 小Z的矩阵

    P2117 小Z的矩阵 题目描述 小Z最近迷上了矩阵,他定义了一个对于一种特殊矩阵的特征函数G.对于N*N的矩阵A,A的所有元素均为0或1,则G(A)等于所有A[i][j]*A[j][i]的和对2取余 ...

  7. 洛谷 2187 小Z的笔记

    [题解] DP.  设f[i]表示前i个字母,保留第i个字母,最多可以保留多少个字母:设g[i]为当前字母为i的位置对应的f的最大值. 转移方程就是f[i]=max(f[i], g[j]+1) (j与 ...

  8. [洛谷P2186] 小Z的栈函数

    题目链接: 传送门 题目分析: 大模拟,先得存操作,然后再处理每个数-- 有一个小优化,在处理操作的时候顺便判一下最后栈里是不是有且仅有一个数,但A完了才想起来,所以就算了-- 总之就是个模拟题--没 ...

  9. [洛谷P2107] 小Z的AK计划

    题目类型:贪心,堆 传送门:>Here< 题意:给出\(N\)个房间,每个房间距离起点的距离为\(x[i]\),每个房间可以选择进去和不进去,如果进去了那么要\(t[i]\)秒后才能出来. ...

随机推荐

  1. SAP-财务知识点

    [转自 http://blog.itpub.net/195776/viewspace-1023912/] SAP FI/CO Reading RepositorySAP财务成本知识库 目 录前言.一. ...

  2. Error setting property values; nested exception is org.springframework.beans.NotWritablePropertyException: Invalid property 'URIType' of bean class

    查阅了资料原始JDK的问题.解决方法 1.重新安装JDK为1.7版本 2.修改配置 1.webx的依赖改为3.1.6版: <dependency> <groupId>com.a ...

  3. ubuntu删除文件夹

    -r表示强制删除,-f表示不提示 强制删除文件夹并提示 sudo rm -r 文件夹名 强制删除文件夹不提示 (最暴力) sudo rm -rf 文件夹名

  4. Java基础教程:JDBC编程

    Java基础教程:JDBC编程 1.什么是JDBC JDBC 指 Java 数据库连接,是一种标准Java应用编程接口( JAVA API),用来连接 Java 编程语言和广泛的数据库. JDBC A ...

  5. ruby 字符串

    字符串处理函数 1.返回字符串的长度 str.length => integer 2.判断字符串中是否包含另一个串 str.include? other_str => true or fa ...

  6. 7-4 汉密尔顿回路(25 分) 【STL】

    7-4 汉密尔顿回路(25 分) 著名的"汉密尔顿(Hamilton)回路问题"是要找一个能遍历图中所有顶点的简单回路(即每个顶点只访问 1 次).本题就要求你判断任一给定的回路是 ...

  7. 高通MSM8255 GPS 调试分析&&Android系统之Broadcom GPS 移植【转】

    本文转载自:http://blog.csdn.net/gabbzang/article/details/12063031 http://blog.csdn.NET/dwyane_zhang/artic ...

  8. SQL Server 2008R2 代理服务-开启

    ,点击开始菜单-所有程序-SQLServer2008R2-配置工具-SQLServer配置管理器 2,选择SQLServer服务 3,找到SqlServer代理(MSSQLSERVER),双击或右键选 ...

  9. 程序猿老公去米国参加 WWDC,顺便想带渡老婆蜜月,如何办签证?

    这个问题要拆开描述比较好:1. 老公是苹果开发者,抽中了2014 WWDC购票机会,打算自费去参加.如果自己成行,应该办何种签证?2. 顺带,两人新婚半年还未安排蜜月,打算提前几天过去先游览一下西海岸 ...

  10. [原创]java导出excel

    一.需求背景 在项目开发中,经常会遇到导出Excel报表文件的情况,因为很多情况下,我们需要打印Excel报表,虽然在网页上也可以生成报表,但是打印网上里的报表是无法处理排版问题的,所以最好的方式,还 ...