질문
무한한 2 차원 평면에, 우리는 다음과 같은 가정을합니다
도 1은 하나 개의 공간을 이동시킬 수있다;
2, 돌아갈 수없는 것은 (당신의 목적지를 가정하면, 당신은 왼쪽으로 갈 수있다 "최대", 당신은 바로, 당신은 또한 올라갈 수 수 있지만 아래로 갈 수 없다)
3 그리드를 통해 즉시 붕괴는 두 번째 시간을 걸을 수 있습니다.
스텝 번호를 찾는 다른 실시 N을 (동일한가없는만큼 두 단계 공정으로하는 다른 프로그램으로 간주된다).
입력
먼저, 소정의 양의 정수 C를, C 군의 시험 데이터를 나타냈다.
C 다음 행은 각 행은 N (N <= 20)의 정수를 포함 N 이탈 스텝을 나타낸다.
산출
출력 n 개의 단계 프로그램 다른 방식의 총 수를하시기 바랍니다;
출력의 각 행.
입력 샘플
원료
2
. 1
2
샘플 출력
원시
. 3
. 7
피사체에 따르면, A [1] = 3, A [2] = 7, 각 분석 후에 진일보 간다.
오른쪽 위로 이동하고 두 방향으로 두 바로 좌측 방향, 우측 방향을 좌측 이동, 왼쪽으로 세 방향있다
A [3] = (17), 도입 될 수있다 [3] = 41. 분석 조건은 수 a[i] = a[i - 2] + 2 * a[i - 1];
코드를 완료
#include<stdio.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<queue>
#include<math.h>
#include<stdio.h>
#include<string.h>
using namespace std;
int main()
{
int m,n;
cin>>n;
int a[30];
while(n--)
{
cin>>m;
a[1] = 3;
a[2] = 7;
for(int i = 3; i <= m; i++)
a[i] = a[i - 2] + 2 * a[i - 1];
cout<<a[m]<<endl;
}
return 0;
}