【输入格式】
读入一个数N
【输出格式】
输出有多少个数中有偶数个数字3。
【输入样例】
2
【输出样例】
73
【数据规模】
1<=N<=1000
【样例说明】
在所有的2位数字,包含0个3的数有72个,包含2个3的数有1个,共73个
算法分析:
用f[i][0]表示前i位取偶数个3有几种情况,f[i][1]表示前i位取奇数个3有几种情况。
i表示n位数的前i位数字,不是指i位数
则状态转移方程可以表示为:
f[i][0]=f[i-1][0]*9+f[i-1][1];-------f[i][0]=f[i-1][0](第i位可以是0-9中除了3的任意一个数)+f[i-1][1](第i位默认是3)
f[i][1]=f[i-1][0]+f[i-1][1]*9;-------f[i][0]=f[i-1][0](第i位默认是3)+f[i-1][1](第i位可以是0-9中除了3的任意一个数)
边界条件:f[1][1]=1;f[1][0]=9;
import java.util.Scanner;
public class Row {
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner input=new Scanner(System.in);
int a[][]=new int[1001][2];//下标为0的位置空出来
int n=input.nextInt();
if(n<=1) {
System.out.println(9);
}else {
a[1][0]=8;//0-9除了0和3
a[1][1]=1;//只有3
for(int i=2;i<=n;i++) {
a[i][0]=a[i-1][0]*9+a[i-1][1];
a[i][1]=a[i-1][1]*9+a[i-1][0];
}
System.out.println(a[n][0]);
}
}
}