在一个2k×2k(1<=k<=100)的棋盘中恰有一方格被覆盖,如图1(k=2时),现用一缺角的2×2方格(图2为其中缺右下角的一个),去覆盖2k×2k未被覆盖过的方格,求需要类似图2方格总的个数s。如k=1时,s=1;k=2时,s=5
图1
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
3 1 2 3
1 5 21accept:
#include<stdio.h> #include<string.h> #define MAXN 10010 int m[MAXN],pow[MAXN]; void bigpower(int n){int a,b; memset(m,0,sizeof(m)); m[0]=1; for(int i=0;i<n;++i){a=b=0; for(int j=0;j<MAXN;++j){ a=m[j]*2+b; m[j]=a%10; b=a/10; } } int j=MAXN,i; while(!m[--j]); for(i=0,j;j>=0;j--,i++)pow[i]=m[j]; for(j=i-1;j>=0;j--){ if(m[j]){ m[j]--; } else m[j]+=9; } int sum=0,x=0,t=0; for(int k=0;k<i;++k){ sum=sum*10+pow[k]; if(sum>=3)printf("%d",sum/3),t=1; else if(t)printf("0"); sum%=3; } puts(""); } int main(){ int m,k; scanf("%d",&m); while(m--){ scanf("%d",&k); bigpower(k+k); } return 0; }
原文:http://www.cnblogs.com/handsomecui/p/4674928.html