1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#include <bits/stdc++.h>

using namespace std;

int g;
long long n;
long long t[20];
long long dp[20];

int main()
{
	scanf("%lld", &n);
	while(n)
	{
		++g;
		t[g]=n%10;
		n/=10;
	}
	dp[0]=1;
	dp[1]=t[1]+1;
	for(int i=2; i<=g; ++i)
	{
		dp[i]+=dp[i-1]*(t[i]+1);
		if(t[i]==1)
		{
			dp[i]+=dp[i-2]*(9-t[i-1]);
		}
	}
	printf("%lld\n", dp[g]);
	return 0;
}