[CSP-S模拟测试]:小L的数(数位DP+模拟)
题目传送门(内部题132)
输入格式
第一行一个整数$t$。
接下来$t$行每行一个整数$n$。
输出格式
$t$行,每行一个整数表示答案。
样例
样例输入:
4
1818
23123
269105
21093203
样例输出:
1
2
3
3
数据范围与提示
对于前$5\%$的测试数据,满足答案小于等于$1$。
对于前$20\%$的测试数据,满足答案小于等于$2$。
对于前$40\%$的测试数据,满足$n\leqslant 300,000$。
对于前$60\%$的测试数据,满足答案小于等于$3$,$n\leqslant 10^{13}$。
对于前$90\%$的测试数据,满足$t\leqslant 30$。
对于$100\%$的测试数据,满足$1\leqslant n\leqslant 10^{18},1\leqslant t\leqslant 100$。
题解
答案一定不大于$4$,所以可以枚举二元组。
先特判答案为$1$的情况,然后用两个二元组尝试,如果不行在用三个,否则直接输出$4$即可。
考虑如何判断,数位$DP$。
设$dp[i][0/1/2][0/1][0/1][0/1]$表示到了第$i$位,进位为$0/1/2$,三个二元组有没有前导$0$。
转移过程我认为是一个模拟(看我代码就知道了……)。
好多人都说被卡常了,然而我一直$WA$,不过到底是调出来了。
时间复杂度:$\Theta(2043360\times T)$。
期望得分:$100$分。
实际得分:$100$分。
代码时刻
#include<bits/stdc++.h>
using namespace std;
char ch[20];
int s,w[20],tot;
char vis[10];
pair<int,int> F[100];
bool dp[20][3][2][2][2];
void pre_work(){for(int i=0;i<9;i++)for(int j=i+1;j<=9;j++)F[++tot]=make_pair(i,j);}
int ask()
{
int sum=0;
memset(vis,0,sizeof(vis));
for(int i=1;i<=s;i++)
if(!vis[w[i]]){vis[w[i]]=1;sum++;}
if(sum<=2)return 1;
for(int i=1;i<=tot;i++)
{
for(int j=i;j<=tot;j++)
{
memset(dp,0,sizeof(dp));
int a=F[i].first,b=F[i].second;
int c=F[j].first,d=F[j].second;
dp[1][0][0][0][0]=1;
dp[1][0][0][0][1]=1;
dp[1][0][0][1][0]=1;
dp[1][0][0][1][1]=1;
for(int x=1;x<=s;x++)
{
if(dp[x][0][0][0][0])
{
if((a+c)%10==w[x])dp[x+1][(a+c)/10][0][0][0]=dp[x+1][(a+c)/10][0][0][1]=dp[x+1][(a+c)/10][0][1][0]=dp[x+1][(a+c)/10][0][1][1]=1;
if((a+d)%10==w[x])dp[x+1][(a+d)/10][0][0][0]=dp[x+1][(a+d)/10][0][0][1]=dp[x+1][(a+d)/10][0][1][0]=dp[x+1][(a+d)/10][0][1][1]=1;
if((b+c)%10==w[x])dp[x+1][(b+c)/10][0][0][0]=dp[x+1][(b+c)/10][0][0][1]=dp[x+1][(b+c)/10][0][1][0]=dp[x+1][(b+c)/10][0][1][1]=1;
if((b+d)%10==w[x])dp[x+1][(b+d)/10][0][0][0]=dp[x+1][(b+d)/10][0][0][1]=dp[x+1][(b+d)/10][0][1][0]=dp[x+1][(b+d)/10][0][1][1]=1;
}
if(dp[x][1][0][0][0])
{
if((a+c+1)%10==w[x])dp[x+1][(a+c+1)/10][0][0][0]=dp[x+1][(a+c+1)/10][0][0][1]=dp[x+1][(a+c+1)/10][0][1][0]=dp[x+1][(a+c+1)/10][0][1][1]=1;
if((a+d+1)%10==w[x])dp[x+1][(a+d+1)/10][0][0][0]=dp[x+1][(a+d+1)/10][0][0][1]=dp[x+1][(a+d+1)/10][0][1][0]=dp[x+1][(a+d+1)/10][0][1][1]=1;
if((b+c+1)%10==w[x])dp[x+1][(b+c+1)/10][0][0][0]=dp[x+1][(b+c+1)/10][0][0][1]=dp[x+1][(b+c+1)/10][0][1][0]=dp[x+1][(b+c+1)/10][0][1][1]=1;
if((b+d+1)%10==w[x])dp[x+1][(b+d+1)/10][0][0][0]=dp[x+1][(b+d+1)/10][0][0][1]=dp[x+1][(b+d+1)/10][0][1][0]=dp[x+1][(b+d+1)/10][0][1][1]=1;
}
if(dp[x][0][0][0][1])
{
if(w[x]==c)dp[x+1][0][0][0][1]=dp[x+1][0][0][1][1]=1;
if(w[x]==d)dp[x+1][0][0][0][1]=dp[x+1][0][0][1][1]=1;
}
if(dp[x][1][0][0][1])
{
if(w[x]==(c+1)%10)dp[x+1][(c+1)/10][0][0][1]=dp[x+1][(c+1)/10][0][1][1]=1;
if(w[x]==(d+1)%10)dp[x+1][(d+1)/10][0][0][1]=dp[x+1][(d+1)/10][0][1][1]=1;
}
if(dp[x][0][0][1][0])
{
if(w[x]==a)dp[x+1][0][0][1][0]=dp[x+1][0][0][1][1]=1;
if(w[x]==b)dp[x+1][0][0][1][0]=dp[x+1][0][0][1][1]=1;
}
if(dp[x][1][0][1][0])
{
if(w[x]==(a+1)%10)dp[x+1][(a+1)/10][0][1][0]=dp[x+1][(a+1)/10][0][1][1]=1;
if(w[x]==(b+1)%10)dp[x+1][(b+1)/10][0][1][0]=dp[x+1][(b+1)/10][0][1][1]=1;
}
if(dp[x][0][0][1][1]&&!w[x])dp[x+1][0][0][1][1]=1;
if(dp[x][1][0][1][1]&&w[x]==1)dp[x+1][0][0][1][1]=1;
}
if(dp[s+1][0][0][0][0])return 2;
if(dp[s+1][0][0][0][1])return 2;
if(dp[s+1][0][0][1][0])return 2;
if(dp[s+1][0][0][1][1])return 2;
}
}
for(int i=1;i<=tot;i++)
{
for(int j=i;j<=tot;j++)
{
for(int k=j;k<=tot;k++)
{
memset(dp,0,sizeof(dp));
int a=F[i].first,b=F[i].second;
int c=F[j].first,d=F[j].second;
int e=F[k].first,f=F[k].second;
dp[1][0][0][0][0]=1;
dp[1][0][0][0][1]=1;
dp[1][0][0][1][0]=1;
dp[1][0][0][1][1]=1;
dp[1][0][1][0][0]=1;
dp[1][0][1][0][1]=1;
dp[1][0][1][1][0]=1;
dp[1][0][1][1][1]=1;
for(int x=1;x<=s;x++)
{
if(dp[x][0][0][0][0])
{
if((a+c+e)%10==w[x])
{
dp[x+1][(a+c+e)/10][0][0][0]=1;
dp[x+1][(a+c+e)/10][0][0][1]=1;
dp[x+1][(a+c+e)/10][0][1][0]=1;
dp[x+1][(a+c+e)/10][0][1][1]=1;
dp[x+1][(a+c+e)/10][1][0][0]=1;
dp[x+1][(a+c+e)/10][1][0][1]=1;
dp[x+1][(a+c+e)/10][1][1][0]=1;
dp[x+1][(a+c+e)/10][1][1][1]=1;
}
if((a+c+f)%10==w[x])
{
dp[x+1][(a+c+f)/10][0][0][0]=1;
dp[x+1][(a+c+f)/10][0][0][1]=1;
dp[x+1][(a+c+f)/10][0][1][0]=1;
dp[x+1][(a+c+f)/10][0][1][1]=1;
dp[x+1][(a+c+f)/10][1][0][0]=1;
dp[x+1][(a+c+f)/10][1][0][1]=1;
dp[x+1][(a+c+f)/10][1][1][0]=1;
dp[x+1][(a+c+f)/10][1][1][1]=1;
}
if((a+d+e)%10==w[x])
{
dp[x+1][(a+d+e)/10][0][0][0]=1;
dp[x+1][(a+d+e)/10][0][0][1]=1;
dp[x+1][(a+d+e)/10][0][1][0]=1;
dp[x+1][(a+d+e)/10][0][1][1]=1;
dp[x+1][(a+d+e)/10][1][0][0]=1;
dp[x+1][(a+d+e)/10][1][0][1]=1;
dp[x+1][(a+d+e)/10][1][1][0]=1;
dp[x+1][(a+d+e)/10][1][1][1]=1;
}
if((a+d+f)%10==w[x])
{
dp[x+1][(a+d+f)/10][0][0][0]=1;
dp[x+1][(a+d+f)/10][0][0][1]=1;
dp[x+1][(a+d+f)/10][0][1][0]=1;
dp[x+1][(a+d+f)/10][0][1][1]=1;
dp[x+1][(a+d+f)/10][1][0][0]=1;
dp[x+1][(a+d+f)/10][1][0][1]=1;
dp[x+1][(a+d+f)/10][1][1][0]=1;
dp[x+1][(a+d+f)/10][1][1][1]=1;
}
if((b+c+e)%10==w[x])
{
dp[x+1][(b+c+e)/10][0][0][0]=1;
dp[x+1][(b+c+e)/10][0][0][1]=1;
dp[x+1][(b+c+e)/10][0][1][0]=1;
dp[x+1][(b+c+e)/10][0][1][1]=1;
dp[x+1][(b+c+e)/10][1][0][0]=1;
dp[x+1][(b+c+e)/10][1][0][1]=1;
dp[x+1][(b+c+e)/10][1][1][0]=1;
dp[x+1][(b+c+e)/10][1][1][1]=1;
}
if((b+c+f)%10==w[x])
{
dp[x+1][(b+c+f)/10][0][0][0]=1;
dp[x+1][(b+c+f)/10][0][0][1]=1;
dp[x+1][(b+c+f)/10][0][1][0]=1;
dp[x+1][(b+c+f)/10][0][1][1]=1;
dp[x+1][(b+c+f)/10][1][0][0]=1;
dp[x+1][(b+c+f)/10][1][0][1]=1;
dp[x+1][(b+c+f)/10][1][1][0]=1;
dp[x+1][(b+c+f)/10][1][1][1]=1;
}
if((b+d+e)%10==w[x])
{
dp[x+1][(b+d+e)/10][0][0][0]=1;
dp[x+1][(b+d+e)/10][0][0][1]=1;
dp[x+1][(b+d+e)/10][0][1][0]=1;
dp[x+1][(b+d+e)/10][0][1][1]=1;
dp[x+1][(b+d+e)/10][1][0][0]=1;
dp[x+1][(b+d+e)/10][1][0][1]=1;
dp[x+1][(b+d+e)/10][1][1][0]=1;
dp[x+1][(b+d+e)/10][1][1][1]=1;
}
if((b+d+f)%10==w[x])
{
dp[x+1][(b+d+f)/10][0][0][0]=1;
dp[x+1][(b+d+f)/10][0][0][1]=1;
dp[x+1][(b+d+f)/10][0][1][0]=1;
dp[x+1][(b+d+f)/10][0][1][1]=1;
dp[x+1][(b+d+f)/10][1][0][0]=1;
dp[x+1][(b+d+f)/10][1][0][1]=1;
dp[x+1][(b+d+f)/10][1][1][0]=1;
dp[x+1][(b+d+f)/10][1][1][1]=1;
}
}
if(dp[x][1][0][0][0])
{
if((a+c+e+1)%10==w[x])
{
dp[x+1][(a+c+e+1)/10][0][0][0]=1;
dp[x+1][(a+c+e+1)/10][0][0][1]=1;
dp[x+1][(a+c+e+1)/10][0][1][0]=1;
dp[x+1][(a+c+e+1)/10][0][1][1]=1;
dp[x+1][(a+c+e+1)/10][1][0][0]=1;
dp[x+1][(a+c+e+1)/10][1][0][1]=1;
dp[x+1][(a+c+e+1)/10][1][1][0]=1;
dp[x+1][(a+c+e+1)/10][1][1][1]=1;
}
if((a+c+f+1)%10==w[x])
{
dp[x+1][(a+c+f+1)/10][0][0][0]=1;
dp[x+1][(a+c+f+1)/10][0][0][1]=1;
dp[x+1][(a+c+f+1)/10][0][1][0]=1;
dp[x+1][(a+c+f+1)/10][0][1][1]=1;
dp[x+1][(a+c+f+1)/10][1][0][0]=1;
dp[x+1][(a+c+f+1)/10][1][0][1]=1;
dp[x+1][(a+c+f+1)/10][1][1][0]=1;
dp[x+1][(a+c+f+1)/10][1][1][1]=1;
}
if((a+d+e+1)%10==w[x])
{
dp[x+1][(a+d+e+1)/10][0][0][0]=1;
dp[x+1][(a+d+e+1)/10][0][0][1]=1;
dp[x+1][(a+d+e+1)/10][0][1][0]=1;
dp[x+1][(a+d+e+1)/10][0][1][1]=1;
dp[x+1][(a+d+e+1)/10][1][0][0]=1;
dp[x+1][(a+d+e+1)/10][1][0][1]=1;
dp[x+1][(a+d+e+1)/10][1][1][0]=1;
dp[x+1][(a+d+e+1)/10][1][1][1]=1;
}
if((a+d+f+1)%10==w[x])
{
dp[x+1][(a+d+f+1)/10][0][0][0]=1;
dp[x+1][(a+d+f+1)/10][0][0][1]=1;
dp[x+1][(a+d+f+1)/10][0][1][0]=1;
dp[x+1][(a+d+f+1)/10][0][1][1]=1;
dp[x+1][(a+d+f+1)/10][1][0][0]=1;
dp[x+1][(a+d+f+1)/10][1][0][1]=1;
dp[x+1][(a+d+f+1)/10][1][1][0]=1;
dp[x+1][(a+d+f+1)/10][1][1][1]=1;
}
if((b+c+e+1)%10==w[x])
{
dp[x+1][(b+c+e+1)/10][0][0][0]=1;
dp[x+1][(b+c+e+1)/10][0][0][1]=1;
dp[x+1][(b+c+e+1)/10][0][1][0]=1;
dp[x+1][(b+c+e+1)/10][0][1][1]=1;
dp[x+1][(b+c+e+1)/10][1][0][0]=1;
dp[x+1][(b+c+e+1)/10][1][0][1]=1;
dp[x+1][(b+c+e+1)/10][1][1][0]=1;
dp[x+1][(b+c+e+1)/10][1][1][1]=1;
}
if((b+c+f+1)%10==w[x])
{
dp[x+1][(b+c+f+1)/10][0][0][0]=1;
dp[x+1][(b+c+f+1)/10][0][0][1]=1;
dp[x+1][(b+c+f+1)/10][0][1][0]=1;
dp[x+1][(b+c+f+1)/10][0][1][1]=1;
dp[x+1][(b+c+f+1)/10][1][0][0]=1;
dp[x+1][(b+c+f+1)/10][1][0][1]=1;
dp[x+1][(b+c+f+1)/10][1][1][0]=1;
dp[x+1][(b+c+f+1)/10][1][1][1]=1;
}
if((b+d+e+1)%10==w[x])
{
dp[x+1][(b+d+e+1)/10][0][0][0]=1;
dp[x+1][(b+d+e+1)/10][0][0][1]=1;
dp[x+1][(b+d+e+1)/10][0][1][0]=1;
dp[x+1][(b+d+e+1)/10][0][1][1]=1;
dp[x+1][(b+d+e+1)/10][1][0][0]=1;
dp[x+1][(b+d+e+1)/10][1][0][1]=1;
dp[x+1][(b+d+e+1)/10][1][1][0]=1;
dp[x+1][(b+d+e+1)/10][1][1][1]=1;
}
if((b+d+f+1)%10==w[x])
{
dp[x+1][(b+d+f+1)/10][0][0][0]=1;
dp[x+1][(b+d+f+1)/10][0][0][1]=1;
dp[x+1][(b+d+f+1)/10][0][1][0]=1;
dp[x+1][(b+d+f+1)/10][0][1][1]=1;
dp[x+1][(b+d+f+1)/10][1][0][0]=1;
dp[x+1][(b+d+f+1)/10][1][0][1]=1;
dp[x+1][(b+d+f+1)/10][1][1][0]=1;
dp[x+1][(b+d+f+1)/10][1][1][1]=1;
}
}
if(dp[x][2][0][0][0])
{
if((a+c+e+2)%10==w[x])
{
dp[x+1][(a+c+e+2)/10][0][0][0]=1;
dp[x+1][(a+c+e+2)/10][0][0][1]=1;
dp[x+1][(a+c+e+2)/10][0][1][0]=1;
dp[x+1][(a+c+e+2)/10][0][1][1]=1;
dp[x+1][(a+c+e+2)/10][1][0][0]=1;
dp[x+1][(a+c+e+2)/10][1][0][1]=1;
dp[x+1][(a+c+e+2)/10][1][1][0]=1;
dp[x+1][(a+c+e+2)/10][1][1][1]=1;
}
if((a+c+f+2)%10==w[x])
{
dp[x+1][(a+c+f+2)/10][0][0][0]=1;
dp[x+1][(a+c+f+2)/10][0][0][1]=1;
dp[x+1][(a+c+f+2)/10][0][1][0]=1;
dp[x+1][(a+c+f+2)/10][0][1][1]=1;
dp[x+1][(a+c+f+2)/10][1][0][0]=1;
dp[x+1][(a+c+f+2)/10][1][0][1]=1;
dp[x+1][(a+c+f+2)/10][1][1][0]=1;
dp[x+1][(a+c+f+2)/10][1][1][1]=1;
}
if((a+d+e+2)%10==w[x])
{
dp[x+1][(a+d+e+2)/10][0][0][0]=1;
dp[x+1][(a+d+e+2)/10][0][0][1]=1;
dp[x+1][(a+d+e+2)/10][0][1][0]=1;
dp[x+1][(a+d+e+2)/10][0][1][1]=1;
dp[x+1][(a+d+e+2)/10][1][0][0]=1;
dp[x+1][(a+d+e+2)/10][1][0][1]=1;
dp[x+1][(a+d+e+2)/10][1][1][0]=1;
dp[x+1][(a+d+e+2)/10][1][1][1]=1;
}
if((a+d+f+2)%10==w[x])
{
dp[x+1][(a+d+f+2)/10][0][0][0]=1;
dp[x+1][(a+d+f+2)/10][0][0][1]=1;
dp[x+1][(a+d+f+2)/10][0][1][0]=1;
dp[x+1][(a+d+f+2)/10][0][1][1]=1;
dp[x+1][(a+d+f+2)/10][1][0][0]=1;
dp[x+1][(a+d+f+2)/10][1][0][1]=1;
dp[x+1][(a+d+f+2)/10][1][1][0]=1;
dp[x+1][(a+d+f+2)/10][1][1][1]=1;
}
if((b+c+e+2)%10==w[x])
{
dp[x+1][(b+c+e+2)/10][0][0][0]=1;
dp[x+1][(b+c+e+2)/10][0][0][1]=1;
dp[x+1][(b+c+e+2)/10][0][1][0]=1;
dp[x+1][(b+c+e+2)/10][0][1][1]=1;
dp[x+1][(b+c+e+2)/10][1][0][0]=1;
dp[x+1][(b+c+e+2)/10][1][0][1]=1;
dp[x+1][(b+c+e+2)/10][1][1][0]=1;
dp[x+1][(b+c+e+2)/10][1][1][1]=1;
}
if((b+c+f+2)%10==w[x])
{
dp[x+1][(b+c+f+2)/10][0][0][0]=1;
dp[x+1][(b+c+f+2)/10][0][0][1]=1;
dp[x+1][(b+c+f+2)/10][0][1][0]=1;
dp[x+1][(b+c+f+2)/10][0][1][1]=1;
dp[x+1][(b+c+f+2)/10][1][0][0]=1;
dp[x+1][(b+c+f+2)/10][1][0][1]=1;
dp[x+1][(b+c+f+2)/10][1][1][0]=1;
dp[x+1][(b+c+f+2)/10][1][1][1]=1;
}
if((b+d+e+2)%10==w[x])
{
dp[x+1][(b+d+e+2)/10][0][0][0]=1;
dp[x+1][(b+d+e+2)/10][0][0][1]=1;
dp[x+1][(b+d+e+2)/10][0][1][0]=1;
dp[x+1][(b+d+e+2)/10][0][1][1]=1;
dp[x+1][(b+d+e+2)/10][1][0][0]=1;
dp[x+1][(b+d+e+2)/10][1][0][1]=1;
dp[x+1][(b+d+e+2)/10][1][1][0]=1;
dp[x+1][(b+d+e+2)/10][1][1][1]=1;
}
if((b+d+f+2)%10==w[x])
{
dp[x+1][(b+d+f+2)/10][0][0][0]=1;
dp[x+1][(b+d+f+2)/10][0][0][1]=1;
dp[x+1][(b+d+f+2)/10][0][1][0]=1;
dp[x+1][(b+d+f+2)/10][0][1][1]=1;
dp[x+1][(b+d+f+2)/10][1][0][0]=1;
dp[x+1][(b+d+f+2)/10][1][0][1]=1;
dp[x+1][(b+d+f+2)/10][1][1][0]=1;
dp[x+1][(b+d+f+2)/10][1][1][1]=1;
}
}
if(dp[x][0][0][0][1])
{
if((c+e)%10==w[x])dp[x+1][(c+e)/10][0][0][1]=dp[x+1][(c+e)/10][0][1][1]=dp[x+1][(c+e)/10][1][0][1]=dp[x+1][(c+e)/10][1][1][1]=1;
if((c+f)%10==w[x])dp[x+1][(c+f)/10][0][0][1]=dp[x+1][(c+f)/10][0][1][1]=dp[x+1][(c+f)/10][1][0][1]=dp[x+1][(c+f)/10][1][1][1]=1;
if((d+e)%10==w[x])dp[x+1][(d+e)/10][0][0][1]=dp[x+1][(d+e)/10][0][1][1]=dp[x+1][(d+e)/10][1][0][1]=dp[x+1][(d+e)/10][1][1][1]=1;
if((d+f)%10==w[x])dp[x+1][(d+f)/10][0][0][1]=dp[x+1][(d+f)/10][0][1][1]=dp[x+1][(d+f)/10][1][0][1]=dp[x+1][(d+f)/10][1][1][1]=1;
}
if(dp[x][1][0][0][1])
{
if((c+e+1)%10==w[x])dp[x+1][(c+e+1)/10][0][0][1]=dp[x+1][(c+e+1)/10][0][1][1]=dp[x+1][(c+e+1)/10][1][0][1]=dp[x+1][(c+e+1)/10][1][1][1]=1;
if((c+f+1)%10==w[x])dp[x+1][(c+f+1)/10][0][0][1]=dp[x+1][(c+f+1)/10][0][1][1]=dp[x+1][(c+f+1)/10][1][0][1]=dp[x+1][(c+f+1)/10][1][1][1]=1;
if((d+e+1)%10==w[x])dp[x+1][(d+e+1)/10][0][0][1]=dp[x+1][(d+e+1)/10][0][1][1]=dp[x+1][(d+e+1)/10][1][0][1]=dp[x+1][(d+e+1)/10][1][1][1]=1;
if((d+f+1)%10==w[x])dp[x+1][(d+f+1)/10][0][0][1]=dp[x+1][(d+f+1)/10][0][1][1]=dp[x+1][(d+f+1)/10][1][0][1]=dp[x+1][(d+f+1)/10][1][1][1]=1;
}
if(dp[x][2][0][0][1])
{
if((c+e+2)%10==w[x])dp[x+1][(c+e+2)/10][0][0][1]=dp[x+1][(c+e+2)/10][0][1][1]=dp[x+1][(c+e+2)/10][1][0][1]=dp[x+1][(c+e+2)/10][1][1][1]=1;
if((c+f+2)%10==w[x])dp[x+1][(c+f+2)/10][0][0][1]=dp[x+1][(c+f+2)/10][0][1][1]=dp[x+1][(c+f+2)/10][1][0][1]=dp[x+1][(c+f+2)/10][1][1][1]=1;
if((d+e+2)%10==w[x])dp[x+1][(d+e+2)/10][0][0][1]=dp[x+1][(d+e+2)/10][0][1][1]=dp[x+1][(d+e+2)/10][1][0][1]=dp[x+1][(d+e+2)/10][1][1][1]=1;
if((d+f+2)%10==w[x])dp[x+1][(d+f+2)/10][0][0][1]=dp[x+1][(d+f+2)/10][0][1][1]=dp[x+1][(d+f+2)/10][1][0][1]=dp[x+1][(d+f+2)/10][1][1][1]=1;
}
if(dp[x][0][0][1][0])
{
if((a+e)%10==w[x])dp[x+1][(a+e)/10][0][1][0]=dp[x+1][(a+e)/10][0][1][1]=dp[x+1][(a+e)/10][1][1][0]=dp[x+1][(a+e)/10][1][1][1]=1;
if((a+f)%10==w[x])dp[x+1][(a+f)/10][0][1][0]=dp[x+1][(a+f)/10][0][1][1]=dp[x+1][(a+f)/10][1][1][0]=dp[x+1][(a+f)/10][1][1][1]=1;
if((b+e)%10==w[x])dp[x+1][(b+e)/10][0][1][0]=dp[x+1][(b+e)/10][0][1][1]=dp[x+1][(b+e)/10][1][1][0]=dp[x+1][(b+e)/10][1][1][1]=1;
if((b+f)%10==w[x])dp[x+1][(b+f)/10][0][1][0]=dp[x+1][(b+f)/10][0][1][1]=dp[x+1][(b+f)/10][1][1][0]=dp[x+1][(b+f)/10][1][1][1]=1;
}
if(dp[x][1][0][1][0])
{
if((a+e+1)%10==w[x])dp[x+1][(a+e+1)/10][0][1][0]=dp[x+1][(a+e+1)/10][0][1][1]=dp[x+1][(a+e+1)/10][1][1][0]=dp[x+1][(a+e+1)/10][1][1][1]=1;
if((a+f+1)%10==w[x])dp[x+1][(a+f+1)/10][0][1][0]=dp[x+1][(a+f+1)/10][0][1][1]=dp[x+1][(a+f+1)/10][1][1][0]=dp[x+1][(a+f+1)/10][1][1][1]=1;
if((b+e+1)%10==w[x])dp[x+1][(b+e+1)/10][0][1][0]=dp[x+1][(b+e+1)/10][0][1][1]=dp[x+1][(b+e+1)/10][1][1][0]=dp[x+1][(b+e+1)/10][1][1][1]=1;
if((b+f+1)%10==w[x])dp[x+1][(b+f+1)/10][0][1][0]=dp[x+1][(b+f+1)/10][0][1][1]=dp[x+1][(b+f+1)/10][1][1][0]=dp[x+1][(b+f+1)/10][1][1][1]=1;
}
if(dp[x][2][0][1][0])
{
if((a+e+2)%10==w[x])dp[x+1][(a+e+2)/10][0][1][0]=dp[x+1][(a+e+2)/10][0][1][1]=dp[x+1][(a+e+2)/10][1][1][0]=dp[x+1][(a+e+2)/10][1][1][1]=1;
if((a+f+2)%10==w[x])dp[x+1][(a+f+2)/10][0][1][0]=dp[x+1][(a+f+2)/10][0][1][1]=dp[x+1][(a+f+2)/10][1][1][0]=dp[x+1][(a+f+2)/10][1][1][1]=1;
if((b+e+2)%10==w[x])dp[x+1][(b+e+2)/10][0][1][0]=dp[x+1][(b+e+2)/10][0][1][1]=dp[x+1][(b+e+2)/10][1][1][0]=dp[x+1][(b+e+2)/10][1][1][1]=1;
if((b+f+2)%10==w[x])dp[x+1][(b+f+2)/10][0][1][0]=dp[x+1][(b+f+2)/10][0][1][1]=dp[x+1][(b+f+2)/10][1][1][0]=dp[x+1][(b+f+2)/10][1][1][1]=1;
}
if(dp[x][0][1][0][0])
{
if((a+c)%10==w[x])dp[x+1][(a+c)/10][1][0][0]=dp[x+1][(a+c)/10][1][0][1]=dp[x+1][(a+c)/10][1][1][0]=dp[x+1][(a+c)/10][1][1][1]=1;
if((a+d)%10==w[x])dp[x+1][(a+d)/10][1][0][0]=dp[x+1][(a+d)/10][1][0][1]=dp[x+1][(a+d)/10][1][1][0]=dp[x+1][(a+d)/10][1][1][1]=1;
if((b+c)%10==w[x])dp[x+1][(b+c)/10][1][0][0]=dp[x+1][(b+c)/10][1][0][1]=dp[x+1][(b+c)/10][1][1][0]=dp[x+1][(b+c)/10][1][1][1]=1;
if((b+d)%10==w[x])dp[x+1][(b+d)/10][1][0][0]=dp[x+1][(b+d)/10][1][0][1]=dp[x+1][(b+d)/10][1][1][0]=dp[x+1][(b+d)/10][1][1][1]=1;
}
if(dp[x][1][1][0][0])
{
if((a+c+1)%10==w[x])dp[x+1][(a+c+1)/10][1][0][0]=dp[x+1][(a+c+1)/10][1][0][1]=dp[x+1][(a+c+1)/10][1][1][0]=dp[x+1][(a+c+1)/10][1][1][1]=1;
if((a+d+1)%10==w[x])dp[x+1][(a+d+1)/10][1][0][0]=dp[x+1][(a+d+1)/10][1][0][1]=dp[x+1][(a+d+1)/10][1][1][0]=dp[x+1][(a+d+1)/10][1][1][1]=1;
if((b+c+1)%10==w[x])dp[x+1][(b+c+1)/10][1][0][0]=dp[x+1][(b+c+1)/10][1][0][1]=dp[x+1][(b+c+1)/10][1][1][0]=dp[x+1][(b+c+1)/10][1][1][1]=1;
if((b+d+1)%10==w[x])dp[x+1][(b+d+1)/10][1][0][0]=dp[x+1][(b+d+1)/10][1][0][1]=dp[x+1][(b+d+1)/10][1][1][0]=dp[x+1][(b+d+1)/10][1][1][1]=1;
}
if(dp[x][2][1][0][0])
{
if((a+c+2)%10==w[x])dp[x+1][(a+c+2)/10][1][0][0]=dp[x+1][(a+c+2)/10][1][0][1]=dp[x+1][(a+c+2)/10][1][1][0]=dp[x+1][(a+c+2)/10][1][1][1]=1;
if((a+d+2)%10==w[x])dp[x+1][(a+d+2)/10][1][0][0]=dp[x+1][(a+d+2)/10][1][0][1]=dp[x+1][(a+d+2)/10][1][1][0]=dp[x+1][(a+d+2)/10][1][1][1]=1;
if((b+c+2)%10==w[x])dp[x+1][(b+c+2)/10][1][0][0]=dp[x+1][(b+c+2)/10][1][0][1]=dp[x+1][(b+c+2)/10][1][1][0]=dp[x+1][(b+c+2)/10][1][1][1]=1;
if((b+d+2)%10==w[x])dp[x+1][(b+d+2)/10][1][0][0]=dp[x+1][(b+d+2)/10][1][0][1]=dp[x+1][(b+d+2)/10][1][1][0]=dp[x+1][(b+d+2)/10][1][1][1]=1;
}
if(dp[x][0][0][1][1])
{
if(e==w[x])dp[x+1][0][0][1][1]=dp[x+1][0][1][1][1]=1;
if(f==w[x])dp[x+1][0][0][1][1]=dp[x+1][0][1][1][1]=1;
}
if(dp[x][1][0][1][1])
{
if((e+1)%10==w[x])dp[x+1][(e+1)/10][0][1][1]=dp[x+1][(e+1)/10][1][1][1]=1;
if((f+1)%10==w[x])dp[x+1][(f+1)/10][0][1][1]=dp[x+1][(f+1)/10][1][1][1]=1;
}
if(dp[x][2][0][1][1])
{
if((e+2)%10==w[x])dp[x+1][(e+2)/10][0][1][1]=dp[x+1][(e+2)/10][1][1][1]=1;
if((f+2)%10==w[x])dp[x+1][(f+2)/10][0][1][1]=dp[x+1][(f+2)/10][1][1][1]=1;
}
if(dp[x][0][1][0][1])
{
if(c==w[x])dp[x+1][0][1][0][1]=dp[x][0][1][1][1]=1;
if(d==w[x])dp[x+1][0][1][0][1]=dp[x][0][1][1][1]=1;
}
if(dp[x][1][1][0][1])
{
if((c+1)%10==w[x])dp[x][(c+1)/10][1][0][1]=dp[x][(c+1)/10][1][1][1]=1;
if((d+1)%10==w[x])dp[x][(d+1)/10][1][0][1]=dp[x][(d+1)/10][1][1][1]=1;
}
if(dp[x][2][1][0][1])
{
if((c+2)%10==w[x])dp[x][(c+2)/10][1][0][1]=dp[x][(c+2)/10][1][1][1]=1;
if((d+2)%10==w[x])dp[x][(d+2)/10][1][0][1]=dp[x][(d+2)/10][1][1][1]=1;
}
if(dp[x][0][1][1][0])
{
if(a==w[x])dp[x][0][1][1][0]=dp[x][0][1][1][1]=1;
if(b==w[x])dp[x][0][1][1][0]=dp[x][0][1][1][1]=1;
}
if(dp[x][1][1][1][0])
{
if((a+1)%10==w[x])dp[x][(a+1)/10][1][1][0]=dp[x][(a+1)/10][1][1][1]=1;
if((b+1)%10==w[x])dp[x][(b+1)/10][1][1][0]=dp[x][(b+1)/10][1][1][1]=1;
}
if(dp[x][2][1][1][0])
{
if((a+2)%10==w[x])dp[x][(a+2)/10][1][1][0]=dp[x][(a+2)/10][1][1][1]=1;
if((b+2)%10==w[x])dp[x][(b+2)/10][1][1][0]=dp[x][(b+2)/10][1][1][1]=1;
}
if(dp[x][0][1][1][1]&&w[x]==0)dp[x+1][0][1][1][1]=1;
if(dp[x][1][1][1][1]&&w[x]==1)dp[x+1][0][1][1][1]=1;
if(dp[x][2][1][1][1]&&w[x]==2)dp[x+1][0][1][1][1]=1;
}
if(dp[s+1][0][0][0][0])return 3;
if(dp[s+1][0][0][0][1])return 3;
if(dp[s+1][0][0][1][0])return 3;
if(dp[s+1][0][0][1][1])return 3;
if(dp[s+1][0][1][0][0])return 3;
if(dp[s+1][0][1][0][1])return 3;
if(dp[s+1][0][1][1][0])return 3;
if(dp[s+1][0][1][1][1])return 3;
}
}
}
return 4;
}
int main()
{
int T;scanf("%d",&T);
pre_work();
while(T--)
{
long long x;
scanf("%lld",&x);s=0;
while(x){w[++s]=x%10;x/=10;}
printf("%d\n",ask());
}
return 0;
}
rp++
[CSP-S模拟测试]:小L的数(数位DP+模拟)的更多相关文章
- [CSP-S模拟测试]:简单的填数(贪心+模拟)
题目描述 对于一个长度为$n$,且下标从$1$开始编号的序列$a$,我们定义它是「合法的」,当且仅当它满足以下条件:·$a_1=1$·对于$i\in [1,n),a_i\leqslant a_{i+1 ...
- [CSP-S模拟测试]:小奇挖矿2(DP+赛瓦维斯特定理)
题目背景 小奇飞船的钻头开启了无限耐久+精准采集模式!这次它要将原矿运到泛光之源的矿石交易市场,以便为飞船升级无限非概率引擎. 题目描述 现在有$m+1$个星球,从左到右标号为$0$到$n$,小奇最初 ...
- 洛谷 - P2657 - windy数 - 数位dp
https://www.luogu.org/problemnew/show/P2657 不含前导零且相邻两个数字之差至少为2的正整数被称为windy数. 这道题是个显然到不能再显然的数位dp了. 来个 ...
- 【BZOJ-1026】windy数 数位DP
1026: [SCOI2009]windy数 Time Limit: 1 Sec Memory Limit: 162 MBSubmit: 5230 Solved: 2353[Submit][Sta ...
- bzoj 1026 [SCOI2009]windy数 数位dp
1026: [SCOI2009]windy数 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline ...
- k好数 数位dp
问题描述 如果一个自然数N的K进制表示中任意的相邻的两位都不是相邻的数字,那么我们就说这个数是K好数.求L位K进制数中K好数的数目.例如K = 4,L = 2的时候,所有K好数为11.13.20.22 ...
- bzoj 3530: [Sdoi2014]数数 数位dp
题目 我们称一个正整数N是幸运数,当且仅当它的十进制表示中不包含数字串集合S中任意一个元素作为其子串.例如当S=(22,333,0233)时,233是幸运数,2333.20233.3223不是幸运数. ...
- hdu3652(含有13且能被13整除的数)数位DP基础
B-number Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Su ...
- BZOJ 3326 [SCOI2013]数数 (数位DP)
洛谷传送门 题目: Fish 是一条生活在海里的鱼,有一天他很无聊,就开始数数玩.他数数玩的具体规则是: 确定数数的进制$B$ 确定一个数数的区间$[L, R]$ 对于$[L, R] $间的每一个数, ...
随机推荐
- mysql 相关文章
<58到家MySQL军规升级版> <数据库索引,到底是什么做的?> <MyISAM与InnoDB的索引差异究竟是啥?> <InnoDB,为何并发如此之高?&g ...
- 记Tomcat进程stop卡住问题定位处理
部分内容参考自CSDN 测试环境通过agent注入了部分代码,其中包括几个Timer. 在通过启动脚本重启tomcat时,会一直有一个stop进程卡住,导致tomcat无法正常重启,进程卡住不动. 通 ...
- Java中字符串排序
package com.fs.test; import java.util.ArrayList; import java.util.Collections; import java.util.List ...
- iOS用contenteditable滚动时,光标不会刷新定位的处理方法
分析 iOS的 wkwebview 在滚动时会暂停许多动画,作为优化 解决思路 监听滚动事件,利用文档重绘即可刷新动画 ps:因为滚动有惯性,touchmove事件只能监听到手指松开的那一刻,所以只能 ...
- Linux下make cmake 编译等啥意思?
写程序大体步骤为: 1.用编辑器编写源代码,如.c文件. 2.用编译器编译代码生成目标文件,如.o. 3.用链接器连接目标代码生成可执行文件,如.exe. 但如果源文件太多,一个一个编译时就会特别麻烦 ...
- CentOS7搭建FastDFS V5.11分布式文件系统(二)
1.CentOS7 FastDFS搭建 前面已下载好了要用到的工具集,下面就可以开始安装了: 如果安装过程中出现问题,可以下载我提供的,当前测试可以通过的工具包: 点这里点这里 1.1 安装libfa ...
- openstack云主机冷迁移
1:开启nova计算节点之间互信 冷迁移需要nova计算节点之间使用nova用户互相免密码访问 默认nova用户禁止登陆,开启所有计算节点的nova用户登录shell. usermod -s /bin ...
- python连接activemq
介绍 activeMQ是一款消息队列,关于消息队列是什么这里就不再介绍了,这里只介绍如何使用python去连接activemq进行消息的发送和接收.既然都用python去连接了,那么对于消息队列是什么 ...
- RaspberryPi交叉编译环境配置-Ubuntu & wiringPi & Qt
1.配置RaspberryPi交叉编译环境: 在开发RaspberryPi Zero的过程中,由于Zero板卡的CPU的处理性能比较弱,因此其编译的性能比较弱,需要将代码在PC电脑上交叉编译完成之后再 ...
- Jdk1.8的安装(Linux和windows)
1.1 JDK1.8下载地址 JDK下载:http://www.oracle.com/technetwork/java/javase/downloads/jdk8-downloads-2133151. ...