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:
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
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
Kaedah: Kaedah membuat timbunan sampel, panggilan main
untuk menyusunnya, dan kemudian mencetak timbunan yang disusun. sortStack
<code class="language-java">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); } }</integer></integer></integer></code>
output:
<code>Original Stack: [4, 2, 9, 7] Sorted Stack in Descending Order: [9, 7, 4, 2]</code>
kerumitan masa dan ruang:
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!