Rumah Java javaTutorial Melaksanakan Kaedah padam

Melaksanakan Kaedah padam

Jul 25, 2024 am 10:39 AM

Memadamkan elemen daripada pokok AVL adalah sama seperti memadamkannya daripada BST, kecuali pokok itu mungkin perlu diseimbangkan semula. Seperti yang dibincangkan dalam Bahagian, Memadam Elemen daripada BST, untuk memadamkan elemen daripada pokok binari, algoritma mula-mula mencari nod yang mengandungi elemen. Biarkan arus menghala ke nod yang mengandungi elemen dalam pepohon binari dan induk menghala ke induk nod semasa. Nod semasa mungkin anak kiri atau anak kanan nod ibu bapa.
Dua kes timbul apabila memadamkan elemen.

Kes 1: Nod semasa tidak mempunyai anak kiri, seperti yang ditunjukkan dalam Rajah di bawah (a). Untuk memadamkan nod semasa, hanya sambungkan nod induk dengan anak kanan nod semasa, seperti ditunjukkan dalam Rajah di bawah (b). Ketinggian nod di sepanjang laluan dari nod induk sehingga akar mungkin telah berkurangan. Untuk memastikan pokok itu seimbang, mohon

balancePath(parent.element);

Implementing the delete Method

Kes 2: Nod semasa mempunyai anak kiri. Biarkan rightMost menghala ke nod yang mengandungi elemen terbesar dalam subpokok kiri nod semasa dan parentOfRightMost menghala ke nod induk rightMost nod, seperti yang ditunjukkan dalam Rajah di bawah (a). Nod Paling kanan tidak boleh mempunyai anak kanan tetapi mungkin mempunyai anak kiri. Gantikan nilai elemen dalam nod semasa dengan satu dalam nod rightMost, sambungkan nod parentOfRightMost dengan anak kiri rightMost nod, dan padamkan nod rightMost, seperti ditunjukkan dalam Rajah di bawah (b).

Image description

Ketinggian nod di sepanjang laluan dari parentOfRightMost sehingga ke akar mungkin telah berkurangan. Untuk memastikan pokok itu seimbang, mohon

balancePath(parentOfRightMost);

Atas ialah kandungan terperinci Melaksanakan Kaedah padam. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan Laman Web ini
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

Tag artikel panas

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1

Hantar Studio 13.0.1

Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte Mar 07, 2025 pm 06:09 PM

Rangka Kerja 4 JavaScript teratas pada tahun 2025: React, Angular, Vue, Svelte

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka? Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka? Mar 17, 2025 pm 05:35 PM

Bagaimanakah mekanisme kelas muatan Java berfungsi, termasuk kelas yang berbeza dan model delegasi mereka?

Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan? Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan? Mar 17, 2025 pm 05:46 PM

Bagaimanakah saya menggunakan Maven atau Gradle untuk Pengurusan Projek Java Lanjutan, Membina Automasi, dan Resolusi Ketergantungan?

Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru Mar 07, 2025 pm 06:12 PM

Node.js 20: Peningkatan Prestasi Utama dan Ciri -ciri Baru

Iceberg: Masa Depan Jadual Data Tasik Iceberg: Masa Depan Jadual Data Tasik Mar 07, 2025 pm 06:31 PM

Iceberg: Masa Depan Jadual Data Tasik

Bagaimanakah saya dapat melaksanakan teknik pengaturcaraan berfungsi di Java? Bagaimanakah saya dapat melaksanakan teknik pengaturcaraan berfungsi di Java? Mar 11, 2025 pm 05:51 PM

Bagaimanakah saya dapat melaksanakan teknik pengaturcaraan berfungsi di Java?

Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas? Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas? Mar 17, 2025 pm 05:43 PM

Bagaimanakah saya boleh menggunakan JPA (Java Constence API) untuk pemetaan objek-objek dengan ciri-ciri canggih seperti caching dan malas malas?

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu? Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu? Mar 17, 2025 pm 05:44 PM

Bagaimanakah saya melaksanakan caching pelbagai peringkat dalam aplikasi java menggunakan perpustakaan seperti kafein atau cache jambu?

See all articles