cari
RumahJavajavaTutorialPanjang kurungan kurungan seimbang terpanjang menggunakan java

Length of longest balanced parentheses prefix using Java

Artikel ini menerangkan cara menggunakan Java untuk mencari panjang kurungan yang paling lama seimbang. Pertama, kita akan memahami masalah menggunakan beberapa contoh dan kemudian belajar dua pendekatan yang berbeza untuk mencarinya.

Penjelasan masalah

Di sini kita memberikan rentetan yang mengandungi kurungan dan kita perlu mencari panjang set kurungan seimbang dari rentetan. Dalam erti kata lain, jika terdapat semua kurungan pembukaan

"(" ")"

, maka kita panggil ia seimbang.

awalan menentukan set seimbang dari awal rentetan. Sebagai contoh, untuk set kurungan '(()) ()', hanya '(())' dipertimbangkan. senario input dan output

Untuk pemahaman yang lebih baik, mari kita lihat beberapa senario input dan output.

Jika rentetan input adalah

"(()"

, awalan kurungan seimbang adalah

()
    , jadi panjangnya adalah 2.
  • Jika rentetan input adalah "((() ())) (((" , kurungan kurungan seimbang adalah ((() ()))) Jadi panjangnya 8.
  • Jika rentetan input adalah "(() ()) () ()" , kurungan kurungan seimbang adalah (() ()) , jadi panjang adalah 6.
  • Panjang kurungan kurungan seimbang yang paling lama dapat dijumpai seperti berikut: menggunakan struktur data stack
  • Count Pembukaan dan Penutup Pandangan

menggunakan struktur data stack
  • tumpukan boleh digunakan. Sekiranya anda mendapati tanda kurung pembukaan '
  • (
  • ' dari timbunan, tolaknya ke timbunan. Jika anda menemui tanda kurung penutup, pop timbunan dan tambah pembolehubah kaunter dengan 2 (baki panjang pasangan Anda mendapat 2.) Teruskan melakukan ini dan mengembalikan pemboleh ubah kaunter apabila ia menjadi timbunan kosong
  • Algoritma

Algoritma adalah seperti berikut:

Jika watak itu

(

, tolaknya ke timbunan.

Jika aksara

adalah

)
<code><p><b>ステップ1:</b>スタックとカウンタを初期化します。</p>
<p><b>ステップ2:</b>文字列の各文字を反復処理します。</p></code>
, muncul timbunan.
  • Meningkatkan kaunter dengan 2. Semak jika timbunan kosong.
  • Jika ia kosong, berakhir gelung.
  • Langkah 3:
  • Kembalikan kaunter pada akhir.
  • Contoh

    <code><p><b>ステップ1:</b>スタックとカウンタを初期化します。</p>
    <p><b>ステップ2:</b>文字列の各文字を反復処理します。</p></code>

    output

    rentetan input ialah: ((()) ((( Panjang kurungan kurungan seimbang yang paling lama ialah: 6

    Count Pembukaan dan Penutup Pandangan

    Pendekatan ini menggunakan dua pembolehubah: kiraan dan panjang. Jika watak itu " (" dari rentetan, kiraan kenaikan sebanyak 1; jika watak itu "

    )

    ", kiraan pengurangan sebanyak 1 dan panjang kenaikan sebanyak 2. Semak jika kiraan adalah 0, jika ia adalah 0, keluar dari gelung dan panjang kembali. Contoh

    output
    import java.util.Stack;
    
    public class Example {
       public static int longestBalancedPrefix(String s) {
          Stack<Character> stack = new Stack<>();
          int count = 0;
          for (int i = 0; i < s.length(); i++) {
             char c = s.charAt(i);
             if (c == '(') {
                stack.push(c);
             } else if (c == ')') {
                if (!stack.isEmpty()) {
                   stack.pop();
                   count += 2;
                }
             }
             if (stack.isEmpty()) {
                break;
             }
          }
          return count;
       }
    
       public static void main(String[] args) {
          String s = "((())(((";
          int length = longestBalancedPrefix(s);
          System.out.println("入力文字列は:" + s);
          System.out.println("最長のバランスの取れた括弧のプレフィックスの長さは:" + length);
       }
    }

    rentetan input adalah ((()) ()) (())) Panjang Panjang Parentheses yang paling lama adalah 8

Atas ialah kandungan terperinci Panjang kurungan kurungan seimbang terpanjang 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
Adakah platform Java bebas jika bagaimana?Adakah platform Java bebas jika bagaimana?May 09, 2025 am 12:11 AM

Java adalah platform-bebas kerana falsafah reka bentuk "Write Once, Run, Run Everywhere", yang bergantung kepada mesin maya Java (JVMS) dan bytecode. 1) Kod Java disusun menjadi bytecode, ditafsirkan oleh JVM atau disusun dengan lalat secara tempatan. 2) Perhatikan kebergantungan perpustakaan, perbezaan prestasi dan konfigurasi persekitaran. 3) Menggunakan perpustakaan standard, ujian silang platform dan pengurusan versi adalah amalan terbaik untuk memastikan kebebasan platform.

Kebenaran mengenai kemerdekaan platform Java: Adakah ia benar -benar mudah?Kebenaran mengenai kemerdekaan platform Java: Adakah ia benar -benar mudah?May 09, 2025 am 12:10 AM

Java'splatformindependencenotsimple; itinvolvescomplexities.1) jvmcompatibilitymustbeensuredacrossplatforms.2) nativelibrariesandsystemcallsneedcarefulhandling.3)

Kemerdekaan Platform Java: Kelebihan untuk Aplikasi WebKemerdekaan Platform Java: Kelebihan untuk Aplikasi WebMay 09, 2025 am 12:08 AM

Java'splatformindependenceBenefitswebapplicationsbyAllowingCodeToRunonAnySystemWithAjvm, SimplifyDeploymentandscaling.Itenables: 1) EasyDeploymentAcsDifferentservers, 2)

JVM menjelaskan: Panduan Komprehensif ke Mesin Maya JavaJVM menjelaskan: Panduan Komprehensif ke Mesin Maya JavaMay 09, 2025 am 12:04 AM

Thejvmistheruntimeenvironmentforexecutingjavabytecode, crucialforjava's "writeonce, runanywhere" keupayaan

Ciri -ciri utama Java: Mengapa ia kekal sebagai bahasa pengaturcaraan teratasCiri -ciri utama Java: Mengapa ia kekal sebagai bahasa pengaturcaraan teratasMay 09, 2025 am 12:04 AM

JavaremainsatopchoiceFordevelopersDuetoitsplatformindant, Objek-OrientedDesign, StrongTyping, AutomaticMemoryManagement, danComprehensivestandardlibrary.ThesefeatureSmakejavaversatileAndPowerforful

Kemerdekaan Platform Java: Apa maksudnya bagi pemaju?Kemerdekaan Platform Java: Apa maksudnya bagi pemaju?May 08, 2025 am 12:27 AM

Java'splatformindependencemeansdeveloperscanwritecodeonceandrunitonanydeviceWithoutrecompiling.thisisachievedthroughthejavirtualmachine (jvm), yang tidak dapat diperbaiki

Bagaimana untuk menyediakan JVM untuk penggunaan pertama?Bagaimana untuk menyediakan JVM untuk penggunaan pertama?May 08, 2025 am 12:21 AM

Untuk menyediakan JVM, anda perlu mengikuti langkah -langkah berikut: 1) Muat turun dan pasang JDK, 2) Tetapkan Pembolehubah Alam Sekitar, 3) Sahkan pemasangan, 4) Tetapkan IDE, 5) Uji program pelari. Menyediakan JVM bukan sekadar membuatnya berfungsi, ia juga melibatkan pengoptimuman peruntukan memori, pengumpulan sampah, penalaan prestasi, dan pengendalian ralat untuk memastikan operasi yang optimum.

Bagaimana saya boleh menyemak kemerdekaan platform java untuk produk saya?Bagaimana saya boleh menyemak kemerdekaan platform java untuk produk saya?May 08, 2025 am 12:12 AM

Toensurejavaplatformindantret, ikuti: 1) compileAndRunyourapplicationonmultiplePlatformsusingdifferentosandjvmversions.2) Utilizeci/cdpipelinesejenkinsorgithubittionsforautomatedcross-platformtesting.3)

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

MinGW - GNU Minimalis untuk Windows

MinGW - GNU Minimalis untuk Windows

Projek ini dalam proses untuk dipindahkan ke osdn.net/projects/mingw, anda boleh terus mengikuti kami di sana. MinGW: Port Windows asli bagi GNU Compiler Collection (GCC), perpustakaan import yang boleh diedarkan secara bebas dan fail pengepala untuk membina aplikasi Windows asli termasuk sambungan kepada masa jalan MSVC untuk menyokong fungsi C99. Semua perisian MinGW boleh dijalankan pada platform Windows 64-bit.

ZendStudio 13.5.1 Mac

ZendStudio 13.5.1 Mac

Persekitaran pembangunan bersepadu PHP yang berkuasa

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.

SublimeText3 versi Inggeris

SublimeText3 versi Inggeris

Disyorkan: Versi Win, menyokong gesaan kod!

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft