Jadual Kandungan
Penerangan Masalah
Penyelesaian
Penjelasan kod
Perkara yang perlu diperhatikan
Meringkaskan
Rumah Java javaTutorial Cari persimpangan dua senarai yang disusun di Kotlin dan padamkan elemen senarai yang berkaitan

Cari persimpangan dua senarai yang disusun di Kotlin dan padamkan elemen senarai yang berkaitan

Oct 01, 2025 am 08:57 AM

Cari persimpangan dua senarai yang disusun di Kotlin dan padamkan elemen senarai yang berkaitan

Artikel ini akan meneroka secara mendalam bagaimana untuk melaksanakan operasi persimpangan senarai yang dipautkan di Kotlin, dan memberikan contoh dan penjelasan kod terperinci.

Pertama, mari kita semak Ringkasan Artikel: Artikel ini memperincikan bagaimana untuk melaksanakan fungsi di Kotlin yang mengira persimpangan dua senarai gelung dua arah yang disusun dan menghilangkan unsur -unsur persimpangan ini dari senarai asal. Fungsi ini menggunakan komparator yang diberikan untuk menyusun senarai yang dipautkan, dan menggunakan semula nod salah satu senarai yang dipautkan untuk membina senarai persimpangan baru, mengelakkan unsur-unsur pendua, dan akhirnya mengembalikan senarai yang tidak disusun tanpa gelung, sentinel yang disusun.

Penerangan Masalah

Memandangkan dua senarai gelung dua arah List1 dan List2, kedua -duanya disusun mengikut urutan menaik mengikut CMMP Comparator. Matlamatnya adalah untuk mencari persimpangan kedua -dua senarai yang dipautkan ini dan membuat senarai yang dipautkan baru yang mengandungi unsur -unsur yang wujud dalam List1 dan List2. Di samping itu, unsur -unsur persimpangan ini perlu dikeluarkan dari senarai yang dipautkan asal List1 dan List2. Senarai yang dipautkan baru mestilah bidirectional, bukan kitaran, dan tidak mengandungi nod sentinel, sambil mengekalkan perintah menaik dan tidak boleh mengandungi unsur-unsur pendua.

Takrif nod nod adalah seperti berikut:

 Node Kelas <e> {
    var Sebelumnya: Node <e>? = null
    var Seterusnya: Node <e>? = null
    Nilai var: e? = null
}</e></e></e>

Penyelesaian

Kod Kotlin berikut melaksanakan fungsi persimpangan, yang digunakan untuk mengira persimpangan dua senarai yang disusun dan memadam elemen dalam senarai yang dipautkan asal:

 Fun <e> persimpangan (List1: Node <e>, List2: Node <e>, CMP: Comparator <e>): Node <e>? {
    Senarai VAR: Node <e>? = null // nod ekor senarai baru yang dipautkan var temp = list1 // penunjuk senarai baru yang dipautkan var temp2 = list2 // penunjuk senarai baru yang dipautkan var count = 0 // merekodkan bilangan nod dalam senarai dikaitkan baru var kepala: nod <e>? = null // nod kepala senarai yang dipautkan baru sementara (temp.next?.value! = null) {// garis senarai yang dipautkan baru
        temp = temp.next !!

        sementara (temp2.next?.Value! = null) {// traversal list2
            temp2 = temp2.next !!
            jika (cmp.compare (temp.value, temp2.value) == 0) {// Cari elemen persimpangan var novo = deleteNode (temp) // padam nod dari list1 if (list! = null) {//
                    list.next = novo
                }
                Senarai = novo // Kemas kini kiraan nod ekor senarai baru yang dipautkan // tambah satu jika (count == 1) {// jika nod pertama, tetapkan senarai nod kepala.previous = null
                    kepala = senarai
                }

                DeletEnode (Temp2) // Padam node Break dari List2; // Setelah mencari elemen persimpangan, lompat keluar dari gelung dalaman}

        }
        temp2 = list2 // Setelah gelung dalaman selesai, tetapkan semula penunjuk Temp2 dan mula melintasi lagi dari kepala List2}


    kembali kepala // kembali ke nod kepala senarai yang dipautkan baru}

FUN <e> DeletEnode (Node: Node <e>): Node <e> {
    var prev = node.previous
    var seterusnya = node.next

    sementara (seterusnya! = null && next.value == node.value) {// Hilangkan elemen pendua seterusnya = next.next
    }


    jika (prev! = null) {
        prev.next = Seterusnya
    }
    jika (seterusnya! = null) {
        Next.Previous = Prev
    }

    Node kembali
}</e></e></e></e></e></e></e></e></e></e>

Penjelasan kod

  1. Fungsi persimpangan:
    • Memulakan Senarai untuk Null untuk membina senarai persimpangan baru.
    • Gunakan temp dan temp2 untuk melangkah ke atas List1 dan List2 masing -masing.
    • Apabila cmp.compare (temp.value, temp2.value) == 0, ini bermakna elemen persimpangan telah dijumpai.
    • Hubungi fungsi DeletEnode untuk memadam nod yang sepadan dari List1 dan List2.
    • Tambah nod yang dipadam ke senarai persimpangan baru.
    • Mengekalkan nod kepala dan ekor senarai yang dipautkan baru.
    • Kembali ke nod kepala senarai yang dipautkan baru.
  2. Fungsi DeletEnode:
    • Padam nod yang ditentukan dari senarai yang dipautkan.
    • Kemas kini petunjuk seterusnya dan sebelumnya dari nod depan dan belakang nod yang dipadam.
    • Logik deduplikasi juga dimasukkan ke dalam fungsi untuk memastikan unsur -unsur pendua dipadam.

Perkara yang perlu diperhatikan

  • Pelaksanaan ini mengandaikan bahawa kedua -dua senarai dikaitkan input List1 dan List2 disusun.
  • Fungsi DeletEnode akan mengubah suai senarai yang dipautkan asal.
  • Pelaksanaan ini menggunakan semula nod List1 untuk membina senarai persimpangan baru.
  • Situasi sempadan perlu dikendalikan dengan baik, seperti senarai yang dipautkan kosong.
  • Oleh kerana senarai yang dipautkan adalah gelung, anda perlu memberi perhatian kepada keadaan gelung semasa traversal untuk mengelakkan gelung tak terhingga.

Meringkaskan

Melalui kod dan penjelasan di atas, kami berjaya melaksanakan fungsi mengira persimpangan dua senarai yang disusun di Kotlin dan memadamkan elemen senarai yang dipautkan asal. Penyelesaian ini dengan cekap menggunakan ciri -ciri senarai yang disusun, dan menyedari pengiraan persimpangan dan pengubahsuaian senarai berkaitan asal dengan memadam nod. Saya harap artikel ini dapat membantu anda memahami dan menggunakan pengetahuan yang relevan mengenai operasi senarai yang dipautkan.

Atas ialah kandungan terperinci Cari persimpangan dua senarai yang disusun di Kotlin dan padamkan elemen senarai yang berkaitan. 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

Alat AI Hot

Undress AI Tool

Undress AI Tool

Gambar buka pakaian secara percuma

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.

Stock Market GPT

Stock Market GPT

Penyelidikan pelaburan dikuasakan AI untuk keputusan yang lebih bijak

Alat 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)

Bagaimana untuk menambah fail balang ke ClassPath di Java? Bagaimana untuk menambah fail balang ke ClassPath di Java? Sep 21, 2025 am 05:09 AM

Gunakan parameter -CP untuk menambah balang ke ClassPath, supaya JVM dapat memuatkan kelas dan sumber dalamannya, seperti Java -Cplibrary.Jarcom.Example.Main, yang menyokong pelbagai balang yang dipisahkan oleh titik -titik komisul atau kolon, dan juga boleh dikonfigurasikan melalui pembolehubah persekitaran kelas atau manifest.mf.

Cara membuat fail di Java Cara membuat fail di Java Sep 21, 2025 am 03:54 AM

UseFile.createenewfile () tocreateafileonlyifitdoesneteTexist, mengelakkan penulisan; 2.preferfiles.createFile () darinio.2formodern, safeFileCreationThatFailSiffileexists;

Bagaimana untuk melaksanakan antara muka di Java? Bagaimana untuk melaksanakan antara muka di Java? Sep 18, 2025 am 05:31 AM

Gunakan kata kunci untuk melaksanakan antara muka. Kelas perlu menyediakan pelaksanaan khusus semua kaedah dalam antara muka. Ia menyokong pelbagai antara muka dan dipisahkan oleh koma untuk memastikan kaedahnya adalah umum. Kaedah lalai dan statik selepas Java 8 tidak perlu ditulis semula.

Membina Aplikasi Extensible dengan Antara Muka Penyedia Perkhidmatan Java (SPI) Membina Aplikasi Extensible dengan Antara Muka Penyedia Perkhidmatan Java (SPI) Sep 21, 2025 am 03:50 AM

Javaspi adalah mekanisme penemuan perkhidmatan terbina dalam JDK, dan melaksanakan pengembangan dinamik berorientasikan antara muka melalui ServicEloader. 1. Tentukan antara muka perkhidmatan dan buat fail yang dinamakan dengan nama penuh antara muka di bawah Meta-INF/Services/, dan tulis nama yang berkelayakan sepenuhnya kelas pelaksanaan; 2. Gunakan serviceLoader.load () untuk memuatkan kelas pelaksanaan, dan JVM secara automatik akan membaca konfigurasi dan instantiate; 3. Kontrak antara muka harus dijelaskan semasa reka bentuk, keutamaan sokongan dan pemuatan bersyarat, dan menyediakan pelaksanaan lalai; 4. Senario aplikasi termasuk akses saluran pelbagai pembayaran dan pengesahan pemalam; 5. Perhatikan prestasi, classpath, pengasingan pengecualian, keselamatan benang dan keserasian versi; 6. Dalam Java9, menyediakan boleh digunakan dalam kombinasi dengan sistem modul.

Pemahaman yang mendalam mengenai hubungan berterusan HTTP: Dasar dan amalan untuk menghantar pelbagai permintaan pada soket yang sama Pemahaman yang mendalam mengenai hubungan berterusan HTTP: Dasar dan amalan untuk menghantar pelbagai permintaan pada soket yang sama Sep 21, 2025 pm 01:51 PM

Artikel ini meneroka mekanisme menghantar banyak permintaan HTTP pada soket TCP yang sama, iaitu, sambungan berterusan HTTP (Keep-Alive). Artikel ini menjelaskan perbezaan antara protokol HTTP/1.X dan HTTP/2, menekankan pentingnya sokongan pelayan untuk sambungan yang berterusan, dan bagaimana untuk mengendalikan sambungan dengan betul: Tepung Response Headers. Dengan menganalisis kesilapan biasa dan menyediakan amalan terbaik, kami berhasrat untuk membantu pemaju membina pelanggan HTTP yang cekap dan mantap.

Memahami Generik Java dan Wildcard Memahami Generik Java dan Wildcard Sep 20, 2025 am 01:58 AM

JavagenericsprovideCompile-timetypesafetyandeliminatecastingingbyallowingtypeparametersonclass, antara muka, andmethods; wildcards (?,? Extendstype ,? supertype) handleunknowntypeswithflexxibility.usoSoRdoRderWildwildwhoRderWildwildwildwildwilddwherwherwilderwilderwilderwilderwildloundwilder .1

Tutorial Java: Cara meratakan arraylist bersarang dan mengisi unsur -unsurnya ke dalam array Tutorial Java: Cara meratakan arraylist bersarang dan mengisi unsur -unsurnya ke dalam array Sep 18, 2025 am 07:24 AM

Tutorial ini terperinci bagaimana untuk memproses arraylists bersarang dengan cekap yang mengandungi arraylists lain di Java dan menggabungkan semua elemen dalamannya ke dalam satu array. Artikel ini akan menyediakan dua penyelesaian teras melalui operasi flatmap API Java 8 Stream: pertama meratakan ke dalam senarai dan kemudian mengisi array, dan secara langsung mewujudkan array baru untuk memenuhi keperluan senario yang berbeza.

Bagaimana cara membaca fail hartanah di Java? Bagaimana cara membaca fail hartanah di Java? Sep 16, 2025 am 05:01 AM

Gunakan kelas Properties untuk membaca fail konfigurasi Java dengan mudah. 1. Masukkan config.properties ke dalam direktori sumber, muatkannya melalui getClassLoader (). 2. Jika fail berada di laluan luaran, gunakan FileInputStream untuk memuatkannya. 3. Gunakan GetProperty (Key, DefaultValue) untuk mengendalikan kekunci yang hilang dan memberikan nilai lalai untuk memastikan pengendalian pengecualian dan pengesahan input.

See all articles