【JZOJ3316】非回文数字
description
如果一个字符串从后往前读与从前往后读一致,我们则称之为回文字符串。当一个数字不包含长度大于1的子回文数字时称为非回文数字。例如,16276是非回文数字,但17276不是,因为它包含回文数字727。
你的任务是在一个给定的范围内计算非回文数字的总数。
analysis
平生最怂的数位\(DP\),询问自然拆开两段做
设\(f[i][j][k][0/1]\)表示做到第\(i\)位、第\(i\)位数字为\(j\)、第\(i-1\)位数字为\(k\)、是否刚好顶上界的合法方案数
转移自然就是\(f[i][j][k][0]+=f[i-1][k][num][0/1]\),注意顶到或不到上界的转移不同
可以知道这样前导\(0\)很难搞,可以换个方法
设\(g[i][j][k]\)表示做到第\(i\)位、第\(i\)位数字为\(j\)、第\(i-1\)位数字为\(k\)的方案数,另外单独转移
也就是说位数不足的一定比原数要小,不需理会上界,相当于这些数都有前导\(0\),都算过了
即钦定\(f\)和\(g\)第一位均不为\(0\)开始\(DP\),最后统计答案把\(f\)和\(g[1..位数-1]\)加一起就好了
code
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#define ll long long
#define fo(i,a,b) for (ll i=a;i<=b;++i)
#define fd(i,a,b) for (ll i=a;i>=b;--i)
using namespace std;
ll f[20][10][10][2];
ll g[20][10][10];
ll a[20];
ll l,r,mx;
inline ll read()
{
ll x=0,f=1;char ch=getchar();
while (ch<'0' || '9'<ch){if (ch=='-')f=-1;ch=getchar();}
while ('0'<=ch && ch<='9')x=x*10+ch-'0',ch=getchar();
return x*f;
}
inline ll get(ll x)
{
if (x<10)return x;
mx=floor(log10(x)+1);
fd(i,mx,1)a[i]=x%10,x/=10;
memset(f,0,sizeof(f));
memset(g,0,sizeof(g));
f[1][a[1]][0][1]=1;
fo(i,1,a[1]-1)f[1][i][0][0]=1;
fo(i,1,9)g[1][i][0]=1;
fo(i,2,mx)
fo(j,0,9)//第i位的数字
fo(k,0,9)//第i-1位的数字
{
if (j==k)continue;
fo(num,0,9)//第i-2位的数字
{
if (i>2 && num==j)continue;
g[i][j][k]+=g[i-1][k][num];
if (j==a[i] && k==a[i-1])
{
f[i][j][k][0]+=f[i-1][k][num][0],
f[i][j][k][1]+=f[i-1][k][num][1];
}
else
{
if (k<a[i-1] || (k==a[i-1] && j<a[i]))
f[i][j][k][0]+=f[i-1][k][num][0]+f[i-1][k][num][1];
else f[i][j][k][0]+=f[i-1][k][num][0];
}
}
}
ll ans=0;
fo(i,1,mx-1)fo(j,0,9)fo(k,0,9)ans+=g[i][j][k];
fo(i,0,9)fo(j,0,9)ans+=f[mx][i][j][0]+f[mx][i][j][1];
return ans;
}
int main()
{
l=read(),r=read();
printf("%lld\n",get(r)-get(l-1));
return 0;
}
【JZOJ3316】非回文数字的更多相关文章
- [LeetCode] Palindrome Number 验证回文数字
Determine whether an integer is a palindrome. Do this without extra space. click to show spoilers. S ...
- javascript 实现一个回文数字
写一个方法,让"1234"变成回文数字“1234321”,就是顺着读和倒着读都是一样的:注:不让用reverse()方法: function palindrome(str){ va ...
- UVALive 2889(回文数字)
题意:给定i,输出第i个回文数字. 分析:1,2,3,4,……,9------------------------------------------------------------------- ...
- Java 简单算法--打印回文数字
package cn.magicdu.algorithm; public class CircleNumber { public static void main(String[] args) { f ...
- [蓝桥杯]PREV-21.历届试题_回文数字
问题描述 观察数字:, 都有一个共同的特征,无论从左到右读还是从右向左读,都是相同的.这样的数字叫做:回文数字. 本题要求你找到一些5位或6位的十进制数字.满足如下要求: 该数字的各个数位之和等于输入 ...
- 【蓝桥杯】PREV-21 回文数字
题目链接:http://lx.lanqiao.org/problem.page? gpid=T113 历届试题 回文数字 时间限制:1.0s 内存限制:256.0MB 问题描写叙 ...
- LeetCode 9 Palindrome Number(回文数字判断)
Long Time No See ! 题目链接https://leetcode.com/problems/palindrome-number/?tab=Description 首先确定该数字的 ...
- 算法笔记_181:历届试题 回文数字(Java)
目录 1 问题描述 2 解决方案 1 问题描述 问题描述 观察数字:12321,123321 都有一个共同的特征,无论从左到右读还是从右向左读,都是相同的.这样的数字叫做:回文数字. 本题要求你找 ...
- 《LeetBook》leetcode题解(9):Palindrome Number[E]——回文数字
我现在在做一个叫<leetbook>的开源书项目,把解题思路都同步更新到github上了,需要的同学可以去看看 地址:https://github.com/hk029/leetcode 这 ...
随机推荐
- Qt无边框窗口的移动、拉伸边框、鼠标滚轮缩放大小
主要是处理窗口上鼠标的几个事件,具体代码请看下面的截图, 完整代码的下载链接在此:http://download.csdn.net/detail/beyond0824/9657110, 本示例代码中, ...
- idea 设置默认maven auto import,不需要每次都弹出
1 2 误区 从这里点进去进行设置,或者每次打开项目右击下方的 auto impot都是不对的.
- jvm监控命令-jstat
jstat 用于查看服务器上某个服务的GC情况. 一般使用方式jstat –gcpid或jstat –utilpid 时间间隔-每个一定时间(指定的时间间隔)输出一次进程pid的内存情况及gc情况. ...
- 剑指offer——26树的子结构
题目描述 输入两棵二叉树A,B,判断B是不是A的子结构.(ps:我们约定空树不是任意一个树的子结构) 题解: 注意,所谓的子结构,是树的形状和值相同,并非判断B是不是A的一部分[如果是这样,那就是 ...
- Phpthink入门基础大全(CURD部分)
[ad code=1 align=center] $data[1]['name'] = ‘阳光雨' $data[1]['email'] = 'sccscc@vip.qq.com' $User>a ...
- FILE_OBJECT
https://msdn.microsoft.com/en-us/library/windows/hardware/ff545834(v=vs.85).aspx The FILE_OBJECT str ...
- mysql 存储过程学习
存储过程框架 DEMILITER $$ -- 重定义符 DROP PROCEDURE IF EXISTS store_procedure$$ -- 如果存在此名的存储过程,先删除 CREATE PRO ...
- mysql 数据库 内容的增删改查
/*所有字段插入值*//*注意插入值数目要与字段值一致*/INSERT INTO student VALUES(1,'熊大','123','2019-10-18',1200);INSERT INTO ...
- oracle将查询结果横转纵
SELECT '残疾人|民政|综合治理|计划生育|物业监管|安全生产|环境类|司法信访|党建|社会组织|文化体育|社保' D , '53|52|51|50|49|48|47|5|4|3|2|1' g ...
- 0924CSP-S模拟测试赛后总结
50分-rank28 我是第二机房垫底大垃圾. 赛时T1和T2其实想到了正解??安慰自己罢了. 真正的CSP-S的赛后你还能和主办方争论说自己其实想到了正解要求人家硬给你个省一不成?? 出题人不知道到 ...