3 1 50 500
0 1 15HintFrom 1 to 500, the numbers that include the sub-sequence "49" are "49","149","249","349","449","490","491","492","493","494","495","496","497","498","499", so the answer is 15.
#include"stdio.h" #include"string.h" #include"iostream" #include"algorithm" #include"math.h" #include"vector" using namespace std; #define LL __int64 #define N 25 LL dp[N][3]; void inti() { memset(dp,0,sizeof(dp)); dp[0][0]=1; int i; for(i=1; i<N; i++) { dp[i][0]=dp[i-1][0]*10-dp[i-1][1]; dp[i][1]=dp[i-1][0]; dp[i][2]=dp[i-1][2]*10+dp[i-1][1]; } } LL work(LL x) { int i,k,flag; int a[N]; LL ans; k=0; while(x) { a[++k]=x%10; x/=10; } a[k+1]=ans=flag=0; for(i=k; i>0; i--) { ans+=a[i]*dp[i-1][2]; if(flag) ans+=a[i]*dp[i-1][0]; else { if(a[i]>4) ans+=dp[i-1][1]; } if(a[i+1]==4&&a[i]==9) flag=1; // printf("%d\n",ans); } return ans; } int main() { int T; LL n; inti(); scanf("%d",&T); while(T--) { scanf("%I64d",&n); printf("%I64d\n",work(n+1)); } return 0; }
原文:http://blog.csdn.net/u011721440/article/details/39647143