oj2568 : 통계 프로그램

질문
무한한 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;
}
게시 38 개 원래 기사 · 원의 찬양 (27) · 전망 3181

추천

출처blog.csdn.net/qq_45891413/article/details/104979266