计蒜客 跳跃游戏
給定一個非負整數數組,假定你的初始位置為數組第一個下標。
數組中的每個元素代表你在那個位置能夠跳躍的最大長度。
請確認你是否能夠跳躍到數組的最后一個下標。
例如:A = [2,3,1,1,4]A=[2,3,1,1,4]?能夠跳躍到最后一個下標,輸出true;
A = [3,2,1,0,4]A=[3,2,1,0,4]?不能跳躍到最后一個下標,輸出false。
輸入格式
第一行輸入一個正整數?n(1 \leq n \leq 500)n(1≤n≤500),接下來的一行?nn?個整數,輸入數組?A_iA?i??。
輸出格式
如果能跳到最后一個下標,輸出true,否則輸出false。
#include<iostream>
using namespace std;
int main()
{
int n;
cin>>n;
int arr[500];
for(int i=0;i<n;i++)
{
cin>>arr[i];
}
int t=0;
int p=0,i,x,max;
while(1)
{
max=-1;
for(i=p;i<=p+arr[p]&&i<n;i++)
{
t=1;
if(arr[i]>max)
{
x=i;
}
}
p=x; //當前位置?
if(p==n-1)
{
cout<<"true";
break;
}
if(t==0||arr[p]==0)
{
cout<<"false";
break;
}
}
}
總結
- 上一篇: 输入参数
- 下一篇: 一种基于平衡二叉树(AVL树)插入、查找