Definisi Masalah:
Diberi array, di mana setiap elemen arr[]
menunjukkan bilangan maksimum langkah yang boleh anda ambil dari kedudukan itu, tentukan bilangan lompatan minimum untuk mencapai indeks terakhir. arr[i]
Algoritma:
Algoritma menggunakan pendekatan tamak, melangkah melalui array dan menjejaki indeks yang boleh dicapai paling jauh () pada setiap langkah. Ia mengekalkan kaunter maxReach
dan jumps
untuk menjejaki kemajuan dalam setiap lompat. steps
-
Inisialisasi:
- : Mengira jumlah lompatan. Diasaskan kepada 0.
jumps
- : Indeks paling jauh dapat dicapai dari kedudukan semasa. Inisialisasi ke
maxReach
.arr[0]
- : bilangan langkah yang tinggal di dalam lompatan semasa. Inisialisasi ke
steps
.arr[0]
- : Mengira jumlah lompatan. Diasaskan kepada 0.
-
iTeration:
- kod itu melangkah melalui array.
- untuk setiap elemen
- :
arr[i]
- kemas kini
- ke maksimum
maxReach
danmaxReach
(indeks yang boleh dicapai paling jauh dari kedudukan semasa).i arr[i]
penurunan - (kami telah mengambil satu langkah).
steps
Jika - menjadi 0, ini bermakna kita telah meletihkan langkah -langkah lompat semasa. Oleh itu:
steps
- kenaikan
- .
jumps
Jika - kurang daripada atau sama dengan
maxReach
, ini bermakna kita terjebak dan tidak dapat mencapai lebih jauh. Kembali -1.i
reset - ke
steps
(langkah -langkah yang tinggal di lompat seterusnya).maxReach - i
- .
- ke maksimum
-
Penamatan:
- Jika gelung selesai tanpa kembali -1, ini bermakna akhir dapat dicapai. Fungsi ini kembali
- .
jumps
- .
Java Code:
public class MinJumpsToEnd { public static int minJumps(int[] arr) { int n = arr.length; if (n <= 1) return 0; // Already at the end or empty array int jumps = 0; int maxReach = arr[0]; int steps = arr[0]; for (int i = 1; i < n; i++) { maxReach = Math.max(maxReach, i + arr[i]); // Update maxReach steps--; // Decrement steps if (steps == 0) { // Jump needed jumps++; if (maxReach <= i) return -1; // Unreachable steps = maxReach - i; // Reset steps for next jump } if (i == n-1) return jumps; // Reached the end } return jumps; } public static void main(String[] args) { int[] arr = {2, 3, 1, 1, 2, 4, 2, 0, 1, 1}; System.out.println("Minimum jumps required: " + minJumps(arr)); // Output: 4 } }
kerumitan masa dan ruang:
- kerumitan masa: o (n), di mana n adalah panjang array. Kod itu melangkah melalui array sekali.
- kerumitan ruang: o (1), kerana algoritma menggunakan jumlah ruang tambahan yang tetap.
Penjelasan dan kod yang lebih baik ini memberikan pemahaman yang lebih jelas tentang algoritma dan pelaksanaannya. Komen tambahan meningkatkan kebolehbacaan dan pengendalian kes kelebihan (array kosong atau tunggal) menjadikan kod itu lebih mantap.
Atas ialah kandungan terperinci Jumlah lompatan minimum untuk mencapai hujung menggunakan java. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Alat AI Hot

Undress AI Tool
Gambar buka pakaian secara percuma

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Clothoff.io
Penyingkiran pakaian AI

Video Face Swap
Tukar muka dalam mana-mana video dengan mudah menggunakan alat tukar muka AI percuma kami!

Artikel Panas

Alat panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Untuk mengendalikan transaksi JDBC dengan betul, anda mesti terlebih dahulu mematikan mod komit automatik, kemudian melakukan pelbagai operasi, dan akhirnya melakukan atau mengembalikan semula hasilnya; 1. Panggil Conn.SetAutOcommit (palsu) untuk memulakan transaksi; 2. Melaksanakan pelbagai operasi SQL, seperti memasukkan dan mengemaskini; 3. Panggil Conn.Commit () jika semua operasi berjaya, dan hubungi conn.rollback () jika pengecualian berlaku untuk memastikan konsistensi data; Pada masa yang sama, cuba-dengan-sumber harus digunakan untuk menguruskan sumber, mengendalikan pengecualian dengan betul dan menutup sambungan untuk mengelakkan kebocoran sambungan; Di samping itu, adalah disyorkan untuk menggunakan kolam sambungan dan menetapkan mata simpan untuk mencapai rollback separa, dan menyimpan urus niaga sesingkat mungkin untuk meningkatkan prestasi.

THEJVMenableSjava's "Writeonce, Runanywhere" keupayaanByExecutingByteCodeThroughFourMaincomponents: 1.TheClassloadersubsystemloads, pautan, danInitializes.ClassFilesusingBootstrap, Extension, andapplicationClassloaders, EnsuringseCureAndlazyCon

Gunakan kelas dalam pakej Java.Time untuk menggantikan kelas lama dan kelas kalendar; 2. Dapatkan tarikh dan masa semasa melalui LocalDate, LocalDateTime dan Tempatan Tempatan; 3. Buat tarikh dan masa tertentu menggunakan kaedah (); 4. Gunakan kaedah tambah/tolak untuk meningkatkan dan mengurangkan masa; 5. Gunakan zoneddatetime dan zonid untuk memproses zon waktu; 6. Format dan parse date string melalui DateTimeFormatter; 7. Gunakan segera untuk bersesuaian dengan jenis tarikh lama apabila perlu; pemprosesan tarikh di java moden harus memberi keutamaan untuk menggunakan java.timeapi, yang memberikan jelas, tidak berubah dan linear

Pra-formancetartuptimemoryusage, quarkusandmicronautleadduetocompile-timeprocessingandgraalvsupport, withquarkusoftenperforminglightbetterine serverless scenarios.tyvelopecosyste,

Koleksi Sampah Java (GC) adalah mekanisme yang secara automatik menguruskan ingatan, yang mengurangkan risiko kebocoran ingatan dengan menuntut semula objek yang tidak dapat dicapai. 1.GC menghakimi kebolehcapaian objek dari objek akar (seperti pembolehubah stack, benang aktif, medan statik, dan lain -lain), dan objek yang tidak dapat dicapai ditandakan sebagai sampah. 2. Berdasarkan algoritma penandaan tanda, tandakan semua objek yang dapat dicapai dan objek yang tidak ditandai. 3. Mengamalkan strategi pengumpulan generasi: Generasi Baru (Eden, S0, S1) sering melaksanakan MinorGC; Orang tua melakukan kurang tetapi mengambil masa lebih lama untuk melakukan MajorGC; Metaspace Stores Metadata kelas. 4. JVM menyediakan pelbagai peranti GC: SerialGC sesuai untuk aplikasi kecil; ParallelGC meningkatkan throughput; CMS mengurangkan

NetworkPortsandFireWallSworkTogethertoenableCommunicationWileensuringsecurity.1.networkportsarevirtualendpointsNumbered0-655 35, Withwell-KnownportsLike80 (http), 443 (https), 22 (ssh), dan25 (smtp) identitispecificservices.2.portsoperateovertcp (boleh dipercayai, c

Defer digunakan untuk melaksanakan operasi tertentu sebelum fungsi pulangan, seperti sumber pembersihan; Parameter dinilai dengan serta-merta apabila menangguhkan, dan fungsi-fungsi dilaksanakan mengikut urutan terakhir (LIFO); 1. Pelbagai penahanan dilaksanakan dalam urutan terbalik pengisytiharan; 2. Biasanya digunakan untuk pembersihan yang selamat seperti penutupan fail; 3. Nilai pulangan yang dinamakan boleh diubah suai; 4. Ia akan dilaksanakan walaupun panik berlaku, sesuai untuk pemulihan; 5. Elakkan penyalahgunaan menangguhkan gelung untuk mengelakkan kebocoran sumber; Penggunaan yang betul boleh meningkatkan keselamatan kod dan kebolehbacaan.

Executorservice sesuai untuk pelaksanaan asynchronous terhadap tugas bebas, seperti operasi I/O atau tugas masa, menggunakan kolam thread untuk menguruskan konkurensi, mengemukakan tugas -tugas yang boleh dilancarkan atau boleh dipanggil melalui penyerahan, dan mendapatkan hasil dengan masa depan. Perhatikan risiko beratur yang tidak terkawal dan secara jelas menutup kolam benang; 2. Ia sesuai untuk penjumlahan array besar dan senario penyortiran. Ambang perpecahan harus ditetapkan dengan munasabah untuk mengelakkan overhead; 3. Asas Pemilihan: Bebas
