cari
RumahJavajavaTutorialProgram Java untuk menyusun unsur -unsur timbunan dalam urutan menurun

Java program to sort the elements of the stack in descending order

Artikel ini menunjukkan cara menyusun unsur -unsur stack dalam urutan menurun menggunakan Java. Tumpukan, mematuhi prinsip terakhir (LIFO), adalah struktur data asas. Fikirkan sejarah penyemak imbas; Tapak yang paling baru -baru ini dikunjungi diakses terlebih dahulu. Kami akan meneroka penyelesaian Java rekursif untuk tugas penyortiran ini.

Masalah:

diberi tumpukan bilangan bulat yang tidak disusun, mengatur unsur -unsurnya dalam urutan menurun (elemen terbesar di bahagian atas).

Contoh input:

<code>Original Stack: [4, 2, 9, 7]</code>

Output Contoh:

<code>Sorted Stack in Descending Order: [9, 7, 4, 2]</code>

Penyelesaian Java Rekursif:

Pendekatan kami menggunakan rekursi untuk menyusun susunan dengan cekap. Proses ini melibatkan langkah -langkah ini:

  1. Kaedah: sortStack(Stack<integer> stack)</integer> Kaedah rekursif ini secara beransur -ansur menghilangkan elemen dari timbunan input sehingga ia kosong. Setiap elemen yang dikeluarkan disimpan sementara, dan kaedah secara rekursif memanggil dirinya pada timbunan yang tinggal. sortStack

  2. Kaedah penolong: sortedInsert(Stack<integer> stack, int element)</integer> Kaedah ini mengendalikan penyisipan unsur -unsur yang dikeluarkan sementara kembali ke dalam timbunan, mengekalkan urutan menurun. Ia memeriksa jika timbunan kosong atau jika elemen dimasukkan lebih besar daripada elemen atas semasa. Jika salah satu keadaan adalah benar, elemen itu ditolak ke timbunan. Jika tidak, elemen teratas dikeluarkan sementara, dipanggil secara rekursif, dan kemudian unsur yang dikeluarkan sementara ditolak. sortedInsert

  3. Kaedah Utama
  4. Kaedah: Kaedah membuat timbunan sampel, panggilan main untuk menyusunnya, dan kemudian mencetak timbunan yang disusun. sortStack

inilah kod Java yang lengkap:

import java.util.Stack;

public class StackSorter {

    public static void sortStack(Stack<Integer> stack) {
        if (!stack.isEmpty()) {
            int top = stack.pop();
            sortStack(stack);
            sortedInsert(stack, top);
        }
    }

    public static void sortedInsert(Stack<Integer> stack, int element) {
        if (stack.isEmpty() || element > stack.peek()) {
            stack.push(element);
            return;
        }
        int temp = stack.pop();
        sortedInsert(stack, element);
        stack.push(temp);
    }

    public static void main(String[] args) {
        Stack<Integer> stack = new Stack<>();
        stack.push(4);
        stack.push(2);
        stack.push(9);
        stack.push(7);

        System.out.println("Original Stack: " + stack);
        sortStack(stack);
        System.out.println("Sorted Stack in Descending Order: " + stack);
    }
}

output:

<code>Original Stack: [4, 2, 9, 7]
Sorted Stack in Descending Order: [9, 7, 4, 2]</code>

kerumitan masa dan ruang:

  • kerumitan masa: o (n 2 ), di mana n adalah bilangan elemen dalam timbunan. Ini disebabkan sifat bersarang panggilan rekursif.
  • kerumitan ruang: o (n) kerana timbunan panggilan rekursif.
Pendekatan rekursif ini memberikan penyelesaian yang jelas dan ringkas untuk menyusun timbunan dalam urutan menurun di Jawa. Penggunaan fungsi pembantu meningkatkan pembacaan dan organisasi kod.

Atas ialah kandungan terperinci Program Java untuk menyusun unsur -unsur timbunan dalam urutan menurun. 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 beberapa strategi untuk mengurangkan isu khusus platform dalam aplikasi Java?Apakah beberapa strategi untuk mengurangkan isu khusus platform dalam aplikasi Java?May 01, 2025 am 12:20 AM

Bagaimanakah Java mengurangkan masalah khusus platform? Java melaksanakan platform bebas melalui JVM dan perpustakaan standard. 1) Gunakan bytecode dan JVM untuk abstrak perbezaan sistem operasi; 2) Perpustakaan standard menyediakan API silang platform, seperti laluan fail pemprosesan kelas Paths, dan pengekodan aksara pemprosesan kelas charset; 3) Gunakan fail konfigurasi dan ujian pelbagai platform dalam projek sebenar untuk pengoptimuman dan debugging.

Apakah hubungan antara kebebasan platform Java dan seni bina microservices?Apakah hubungan antara kebebasan platform Java dan seni bina microservices?May 01, 2025 am 12:16 AM

Java'splatformindependenceEnhancesMicroservicesarchitectureByOfferingDeploymentflexability, konsistensi, skalabilitas, andPortability.1) DeploymentflexabilityAllowsMicroserviceStorunonAnanyplatformWithAjvm.2) ConsistencyAcsServicSservicesSimpliesDevelanDanDevelan

Bagaimanakah GraalVM berkaitan dengan matlamat kemerdekaan platform Java?Bagaimanakah GraalVM berkaitan dengan matlamat kemerdekaan platform Java?May 01, 2025 am 12:14 AM

GraalVM meningkatkan kemerdekaan platform Java dalam tiga cara: 1. 2. Persekitaran Runtime Bebas, menyusun program Java ke dalam fail boleh laku tempatan melalui GraalvmnativeImage; 3. Pengoptimuman Prestasi, Graal Compiler menjana kod mesin yang cekap untuk meningkatkan prestasi dan konsistensi program Java.

Bagaimana anda menguji aplikasi Java untuk keserasian platform?Bagaimana anda menguji aplikasi Java untuk keserasian platform?May 01, 2025 am 12:09 AM

Toeffectivelytestjavaapplicationsforplatformcompatebility, ikutiTheSesteps: 1) setupautomatedtestingacrossmultiplePlatformsusingcitoolslikejenkinsorgithubithubactions.2) conductManualtestingonrealhardwaretocatchiscatscienvironments.2)

Apakah peranan pengkompil Java (JAVAC) dalam mencapai kemerdekaan platform?Apakah peranan pengkompil Java (JAVAC) dalam mencapai kemerdekaan platform?May 01, 2025 am 12:06 AM

Penyusun Java menyedari kemerdekaan platform Java dengan menukar kod sumber ke dalam bytecode bebas platform, yang membolehkan program Java dijalankan pada mana-mana sistem operasi dengan JVM dipasang.

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.

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

Muat turun versi mac editor Atom

Muat turun versi mac editor Atom

Editor sumber terbuka yang paling popular

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Versi Mac WebStorm

Versi Mac WebStorm

Alat pembangunan JavaScript yang berguna

MantisBT

MantisBT

Mantis ialah alat pengesan kecacatan berasaskan web yang mudah digunakan yang direka untuk membantu dalam pengesanan kecacatan produk. Ia memerlukan PHP, MySQL dan pelayan web. Lihat perkhidmatan demo dan pengehosan kami.

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa