cari
RumahJavajavaTutorialJumlah lompatan minimum untuk mencapai hujung menggunakan java

Minimum number of jumps to reach end using Java

Kod Java ini mengira lompatan minimum yang diperlukan untuk melintasi array, di mana setiap elemen mewakili jarak lompat maksimum dari kedudukan tersebut. Mari kita meneroka algoritma dan kod langkah demi langkah. Matlamatnya adalah untuk mencari lompatan paling sedikit yang diperlukan untuk mencapai hujung array, bermula dari indeks 0. Jika akhir tidak dapat dicapai, fungsi kembali -1.

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

  1. 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]
  2. iTeration:

      kod itu melangkah melalui array.
    • untuk setiap elemen
    • : arr[i]
        kemas kini
      • ke maksimum maxReach dan maxReach (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
  3. 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!

Kenyataan
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Apakah kelebihan menggunakan bytecode ke atas kod asli untuk kemerdekaan platform?Apakah kelebihan menggunakan bytecode ke atas kod asli untuk kemerdekaan platform?Apr 30, 2025 am 12:24 AM

BytecodeachievesplatformindependenceBebyBeingExecutedyavirtualMachine (VM), membolehkanCodeTorunonanyplatformWithTheAppropriatevm.Forexample, JavabytecodecanrunonanydeviceVmm, enabling "

Adakah Java benar-benar 100% platform bebas? Mengapa atau mengapa tidak?Adakah Java benar-benar 100% platform bebas? Mengapa atau mengapa tidak?Apr 30, 2025 am 12:18 AM

Java tidak dapat mencapai kemerdekaan platform 100%, tetapi kemerdekaan platformnya dilaksanakan melalui JVM dan bytecode untuk memastikan kod tersebut berjalan pada platform yang berbeza. Pelaksanaan spesifik termasuk: 1. Kompilasi ke bytecode; 2. Tafsiran dan pelaksanaan JVM; 3. Konsistensi Perpustakaan Standard. Walau bagaimanapun, perbezaan pelaksanaan JVM, sistem operasi dan perbezaan perkakasan, dan keserasian perpustakaan pihak ketiga boleh menjejaskan kebebasan platformnya.

Bagaimanakah pemantauan kod sokongan kemerdekaan platform Java?Bagaimanakah pemantauan kod sokongan kemerdekaan platform Java?Apr 30, 2025 am 12:15 AM

Java menyedari kemerdekaan platform melalui "Tulis sekali, jalankan di mana -mana" dan meningkatkan pemeliharaan kod: 1. Penggunaan semula kod tinggi dan mengurangkan pembangunan pendua; 2. Kos penyelenggaraan yang rendah, hanya satu pengubahsuaian yang diperlukan; 3. Kecekapan kerjasama pasukan tinggi adalah tinggi, mudah untuk perkongsian pengetahuan.

Apakah cabaran dalam mewujudkan JVM untuk platform baru?Apakah cabaran dalam mewujudkan JVM untuk platform baru?Apr 30, 2025 am 12:15 AM

Cabaran utama yang dihadapi mewujudkan JVM pada platform baru termasuk keserasian perkakasan, keserasian sistem operasi, dan pengoptimuman prestasi. 1. Keserasian perkakasan: Adalah perlu untuk memastikan bahawa JVM dapat menggunakan set arahan pemproses platform baru, seperti RISC-V. 2. Keserasian sistem operasi: JVM perlu memanggil API sistem platform baru dengan betul, seperti Linux. 3. Pengoptimuman Prestasi: Ujian dan Penalaan Prestasi diperlukan, dan strategi pengumpulan sampah diselaraskan untuk menyesuaikan diri dengan ciri -ciri memori platform baru.

Bagaimanakah perpustakaan Javafx cuba menangani ketidakkonsistenan platform dalam pembangunan GUI?Bagaimanakah perpustakaan Javafx cuba menangani ketidakkonsistenan platform dalam pembangunan GUI?Apr 30, 2025 am 12:01 AM

JavafxeffectivelyaddressesplatforminconsistencyiDevelopmentbybyusingapform-agnosticscenegraphandcsssstyling.1) Itabstractsplatformspecificsthroughascenegraph, memastikan konsistenRenderingAscrosswindows, macoS, danLinux.2)

Terangkan bagaimana JVM bertindak sebagai perantara antara kod Java dan sistem operasi yang mendasari.Terangkan bagaimana JVM bertindak sebagai perantara antara kod Java dan sistem operasi yang mendasari.Apr 29, 2025 am 12:23 AM

JVM berfungsi dengan menukar kod Java ke dalam kod mesin dan menguruskan sumber. 1) Pemuatan Kelas: Muatkan fail kelas. Ke dalam memori. 2) Kawasan data runtime: Menguruskan kawasan memori. 3) Enjin Pelaksanaan: Mentafsirkan atau menyusun bytecode pelaksanaan. 4) Antara muka kaedah tempatan: Berinteraksi dengan sistem operasi melalui JNI.

Terangkan peranan mesin maya Java (JVM) dalam kemerdekaan platform Java.Terangkan peranan mesin maya Java (JVM) dalam kemerdekaan platform Java.Apr 29, 2025 am 12:21 AM

JVM membolehkan Java melintasi platform. 1) Beban JVM, mengesahkan dan melaksanakan bytecode. 2) Kerja JVM termasuk pemuatan kelas, pengesahan bytecode, pelaksanaan tafsiran dan pengurusan ingatan. 3) JVM menyokong ciri -ciri canggih seperti pemuatan dan refleksi kelas dinamik.

Apakah langkah -langkah yang anda ambil untuk memastikan aplikasi Java berjalan dengan betul pada sistem operasi yang berbeza?Apakah langkah -langkah yang anda ambil untuk memastikan aplikasi Java berjalan dengan betul pada sistem operasi yang berbeza?Apr 29, 2025 am 12:11 AM

Aplikasi Java boleh dijalankan pada sistem pengendalian yang berbeza melalui langkah -langkah berikut: 1) Gunakan kelas fail atau laluan untuk memproses laluan fail; 2) menetapkan dan mendapatkan pembolehubah persekitaran melalui System.getenv (); 3) Gunakan Maven atau Gradle untuk menguruskan kebergantungan dan ujian. Keupayaan merentas platform Java bergantung pada lapisan abstraksi JVM, tetapi masih memerlukan pengendalian manual ciri-ciri khusus sistem operasi tertentu.

See all articles

Alat AI Hot

Undresser.AI Undress

Undresser.AI Undress

Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover

AI Clothes Remover

Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

Clothoff.io

Clothoff.io

Penyingkiran pakaian AI

Video Face Swap

Video Face Swap

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

Alat panas

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

SecLists

SecLists

SecLists ialah rakan penguji keselamatan muktamad. Ia ialah koleksi pelbagai jenis senarai yang kerap digunakan semasa penilaian keselamatan, semuanya di satu tempat. SecLists membantu menjadikan ujian keselamatan lebih cekap dan produktif dengan menyediakan semua senarai yang mungkin diperlukan oleh penguji keselamatan dengan mudah. Jenis senarai termasuk nama pengguna, kata laluan, URL, muatan kabur, corak data sensitif, cangkerang web dan banyak lagi. Penguji hanya boleh menarik repositori ini ke mesin ujian baharu dan dia akan mempunyai akses kepada setiap jenis senarai yang dia perlukan.

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

EditPlus versi Cina retak

EditPlus versi Cina retak

Saiz kecil, penyerlahan sintaks, tidak menyokong fungsi gesaan kod