計蒜客 跳躍遊戲

2021-09-01 00:03:23 字數 1506 閱讀 8215

給定乙個非負整數陣列,假定你的初始位置為陣列第乙個下標。

陣列中的每個元素代表你在那個位置能夠跳躍的最大長度。

請確認你是否能夠跳躍到陣列的最後乙個下標。

例如:a=[2,3,1,1,4]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]a=[3,2,1,0,4] 不能跳躍到最後乙個下標,輸出false

第一行輸入乙個正整數 n(1≤n≤500)n(1 \leq n \leq 500)n(1≤n≤500),接下來的一行 nnn 個整數,輸入陣列 aia_iai​。

如果能跳到最後乙個下標,輸出true,否則輸出false

樣例輸入

5

2 0 2 0 1

樣例輸出

true
貪心問題,因為只要跳到最後一格即可,所以只要從最後一格開始。

從第一格跳到最後一格和從最後一格跳到第一格是相同的。

如果從乙個格仔可以跳到最早出現的可以直接跳到最後一格的後面,

那就可以先直接跳到這個格仔,再到終點,

如果不能達到,這個格仔已經是最近的了,肯定不能跳到最後。

找乙個最早出現的可以直接跳到最後一格的,

把這一格變成最後一格,

重複是上面的過程,如果最後一格變為0,就為true,否則為false。

#include#define n 1020

int a[n];

int main()

}if(n!=0)

printf("false\n");

else

printf("true\n");

}return 0;

}

給定乙個非負整數陣列,假定你的初始位置為陣列第乙個下標。

陣列中的每個元素代表你在那個位置能夠跳躍的最大長度。

你的目標是到達最後乙個下標,並且使用最少的跳躍次數。

例如:a=[2,3,1,1,4]a = [2,3,1,1,4]a=[2,3,1,1,4],到達最後乙個下標的最少跳躍次數為 222。(先跳躍 111 步,從下標 000 到 111,然後跳躍 333 步,到達最後乙個下標。一共兩次)

第一行輸入乙個正整數 n(1≤n≤100)n(1 \le n \le 100)n(1≤n≤100) ,接下來的一行,輸入 nnn 個整數,表示陣列 aaa。

最後輸出最少的跳躍次數。

樣例輸入

5

3 1 1 1 1

樣例輸出

2
#include#define n 120

int a[n];

int main()

} printf("%d\n",ans);

return 0;

}

計蒜客 跳躍遊戲

給定乙個非負整數陣列,假定你的初始位置為陣列第乙個下標。陣列中的每個元素代表你在那個位置能夠跳躍的最大長度。請確認你是否能夠跳躍到陣列的最後乙個下標。例如 a 2,3,1,1,4 return true.a 3,2,1,0,4 return false.格式 第一行輸入乙個正整數n,接下來的一行,輸...

計蒜客 跳躍遊戲

描述 給定乙個非負整數陣列,假定你的初始位置為陣列第乙個下標。陣列中的每個元素代表你在那個位置能夠跳躍的最大長度。請確認你是否能夠跳躍到陣列的最後乙個下標。例如 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 不能...

計蒜客 跳躍遊戲

跳躍遊戲 給定乙個非負整數陣列,假定你的初始位置為陣列第乙個下標。陣列中的每個元素代表你在那個位置能夠跳躍的最大長度。請確認你是否能夠跳躍到陣列的最後乙個下標。例如 a 2,3,1,1,4 return true.a 3,2,1,0,4 return false.格式 第一行輸入乙個正整數n,接下來...