commit fbec307216e35dab61b60d6195329c6ca1d0fe82 Author: 86199 Date: Thu Oct 5 18:16:24 2023 +0800 初始化 diff --git a/.gitignore b/.gitignore new file mode 100644 index 0000000..5ff6309 --- /dev/null +++ b/.gitignore @@ -0,0 +1,38 @@ +target/ +!.mvn/wrapper/maven-wrapper.jar +!**/src/main/**/target/ +!**/src/test/**/target/ + +### IntelliJ IDEA ### +.idea/modules.xml +.idea/jarRepositories.xml +.idea/compiler.xml +.idea/libraries/ +*.iws +*.iml +*.ipr + +### Eclipse ### +.apt_generated +.classpath +.factorypath +.project +.settings +.springBeans +.sts4-cache + +### NetBeans ### +/nbproject/private/ +/nbbuild/ +/dist/ +/nbdist/ +/.nb-gradle/ +build/ +!**/src/main/**/build/ +!**/src/test/**/build/ + +### VS Code ### +.vscode/ + +### Mac OS ### +.DS_Store \ No newline at end of file diff --git a/.idea/.gitignore b/.idea/.gitignore new file mode 100644 index 0000000..35410ca --- /dev/null +++ b/.idea/.gitignore @@ -0,0 +1,8 @@ +# 默认忽略的文件 +/shelf/ +/workspace.xml +# 基于编辑器的 HTTP 客户端请求 +/httpRequests/ +# Datasource local storage ignored files +/dataSources/ +/dataSources.local.xml diff --git a/.idea/encodings.xml b/.idea/encodings.xml new file mode 100644 index 0000000..aa00ffa --- /dev/null +++ b/.idea/encodings.xml @@ -0,0 +1,7 @@ + + + + + + + \ No newline at end of file diff --git a/.idea/misc.xml b/.idea/misc.xml new file mode 100644 index 0000000..82dbec8 --- /dev/null +++ b/.idea/misc.xml @@ -0,0 +1,14 @@ + + + + + + + + + + \ No newline at end of file diff --git a/pom.xml b/pom.xml new file mode 100644 index 0000000..4c8c5d0 --- /dev/null +++ b/pom.xml @@ -0,0 +1,17 @@ + + + 4.0.0 + + org.example + demo + 1.0-SNAPSHOT + + + 17 + 17 + UTF-8 + + + diff --git a/src/main/java/org/example/Main.java b/src/main/java/org/example/Main.java new file mode 100644 index 0000000..395337e --- /dev/null +++ b/src/main/java/org/example/Main.java @@ -0,0 +1,34 @@ +package org.example; + +public class Main { + public static int jumpMinSteps(int[] arr) { + int n = arr.length; + if (n <= 1) { + return 0; + } + + int maxRange = arr[0]; // 当前位置能跳跃到的最远位置 + int end = arr[0]; // 当前跳跃能到达的边界 + int steps = 1; // 跳跃步数 + + for (int i = 1; i < n; i++) { + if (i > end) { + // 需要进行一次新的跳跃 + steps++; + end = maxRange; + } + + if (arr[i] + i > maxRange) { + // 更新当前能跳跃到的最远位置 + maxRange = arr[i] + i; + } + } + + return steps; + } + public static void main(String[] args) { + int[] arr = {3, 4, 2, 1, 1, 3, 3, 1, 1}; + int result = jumpMinSteps(arr); + System.out.println("最小步数: " + result); + } +}