mirror of
https://github.com/Kiritow/OJ-Problems-Source.git
synced 2024-03-22 13:11:29 +08:00
Create 2089.cpp
This commit is contained in:
parent
f38d9a11ff
commit
0dcad50d42
55
HDOJ/2089.cpp
Normal file
55
HDOJ/2089.cpp
Normal file
|
@ -0,0 +1,55 @@
|
||||||
|
#include <cstdio>
|
||||||
|
#include <cstdlib>
|
||||||
|
#include <cstring>
|
||||||
|
using namespace std;
|
||||||
|
|
||||||
|
#define MAXLEN 10
|
||||||
|
#define MAXNUM 10
|
||||||
|
int dp[MAXLEN][MAXNUM];
|
||||||
|
int num[MAXLEN];
|
||||||
|
char _tmpbuff[MAXLEN];
|
||||||
|
|
||||||
|
inline int Deal(int N)
|
||||||
|
{
|
||||||
|
sprintf(_tmpbuff,"%d",N);
|
||||||
|
int _len=strlen(_tmpbuff);
|
||||||
|
/// num: 低位存放数字低位(逆序)
|
||||||
|
for(int i=0; i<_len; i++)
|
||||||
|
{
|
||||||
|
num[i]=_tmpbuff[_len-i-1]-'0';
|
||||||
|
}
|
||||||
|
num[_len]=0;
|
||||||
|
int ans=0;
|
||||||
|
for(int i=_len-1; i>=0; i--)
|
||||||
|
{
|
||||||
|
for(int j=0; j<num[i]; j++)
|
||||||
|
{
|
||||||
|
if(num[i+1]==6&&j==2) continue;
|
||||||
|
ans+=dp[i+1][j];///重要 i+1
|
||||||
|
}
|
||||||
|
/// ?
|
||||||
|
if (num[i] == 4 || (num[i + 1] == 6 && num[i] == 2)) break;
|
||||||
|
}
|
||||||
|
return ans;
|
||||||
|
}
|
||||||
|
|
||||||
|
int main()
|
||||||
|
{
|
||||||
|
dp[0][0] = 1;
|
||||||
|
for (int i = 1; i < MAXLEN; ++i)
|
||||||
|
for (int j = 0; j < MAXNUM; ++j)
|
||||||
|
for (int k = 0; k < MAXNUM; ++k)
|
||||||
|
if (j != 4 && !(j == 6 && k == 2))
|
||||||
|
dp[i][j] += dp[i - 1][k];
|
||||||
|
int n,m;
|
||||||
|
while(scanf("%d %d",&n,&m)==2&&!(n==0&&m==0))
|
||||||
|
{
|
||||||
|
/// Calculate M
|
||||||
|
|
||||||
|
int ans_m=Deal(m+1);
|
||||||
|
int ans_n=Deal(n);
|
||||||
|
|
||||||
|
printf("%d\n",ans_m-ans_n);
|
||||||
|
}
|
||||||
|
return 0;
|
||||||
|
}
|
Loading…
Reference in New Issue
Block a user