AcWing 1085. 不要62--模板
原题链接
中等
作者:
_T_
,
2022-01-24 18:26:49
,
所有人可见
,
阅读 213
#include<iostream>
#include<vector>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=15;
int f[N][N];//i位,最高位为j的合法方案数
int l,r;
void init(){
for(int j=0;j<=9;j++){
if(j!=4) f[1][j]=1;
}
for(int i=2;i<N;i++){
for(int j=0;j<=9;j++){
for(int k=0;k<=9;k++){
if(j==4||k==4) continue;
if(j==6&&k==2) continue;
f[i][j]+=f[i-1][k];
}
}
}
}
int dp(int n){
if(!n) return 1;
vector<int> nums;
while(n) nums.push_back(n%10),n/=10;
int res=0;
int last=0;
for(int i=nums.size()-1;i>=0;i--){
int x=nums[i];
for(int j=0;j<x;j++){
if(j==4) continue;
if(last==6&&j==2)continue;
res+=f[i+1][j];//i+1位
}
if(x==4) break;
if(last==6&&x==2) break;
last =x;
if(!i) res++;
}
return res;
}
int main(){
init();
while(cin>>l>>r){
if(l==0&&r==0)break;
cout<<dp(r)-dp(l-1)<<endl;
}
return 0;
}