Jadual Kandungan
Kandungan soalan
Penyelesaian
Rumah Java Cari pasangan GCD untuk tatasusunan yang diberikan

Cari pasangan GCD untuk tatasusunan yang diberikan

Feb 22, 2024 pm 12:37 PM
pembahagi sepunya terbesar susunan

Soal Jawab Java: Mencari pasangan GCD bagi tatasusunan tertentu ialah soalan lazim yang memerlukan pengiraan pembahagi sepunya terbesar (GCD) nombor dalam tatasusunan. Di Java, anda boleh menggunakan algoritma Euclidean untuk menyelesaikan masalah ini. Dalam artikel ini, editor PHP Xigua akan memperkenalkan cara menggunakan Java untuk menulis kaedah mencari pasangan GCD bagi tatasusunan tertentu, membantu pembaca memahami dan menggunakan algoritma ini dengan lebih baik.

Kandungan soalan

Diberi tatasusunan integer saiz n, dengan n ialah nombor genap. Pilih 2 nombor daripada tatasusunan dan cari gcd. Begitu juga, pilih 2 item daripada item yang tinggal dalam tatasusunan dan cari gcd. Ulangi langkah di atas untuk mencari pasangan gcd. Jumlahkan nilai gcd dan dapatkan jumlah tertinggi.

Kekangan:

n is in range 2 to 20
arr[i] is in range 1 to 10^9
Salin selepas log masuk

Contoh 1:

arr = [3,4,9,5]
Salin selepas log masuk

Jawapan:

4
Salin selepas log masuk

Arahan:

a) gcd of (4,5) is 1
b) gcd of (3,9) is 3
sum = 1+3 = 4. this is the highest possible gcd sum.
Salin selepas log masuk

Contoh 2:

arr = [1,2,3,4,5,6]
Salin selepas log masuk

Jawapan:

6
Salin selepas log masuk

Arahan:

a) gcd of (1,5) is 1
b) gcd of (2,4) is 2
c) gcd of (3,6) is 3
sum = 1+2+3 = 6. this is the highest possible gcd sum.
Salin selepas log masuk

Ini kod saya:

public static int solve(int[] ar) {
   int n = ar.length;
   Arrays.sort(ar);
   int sum = 0;
   for(int i=0; i<n/2; i++) {
     int a = ar.get(i), b = ar.get(n-i-1);
     int c = gcd(a,b); 
     sum += c;
   }
   return sum;
}

static int gcd(int a, int b)
{
    // if b=0, a is the GCD
    if (b == 0)
        return a;

    // call the gcd() method recursively by
    // replacing a with b and b with
    // modulus(a,b) as long as b != 0
    else
        return gcd(b, a % b);
}
Salin selepas log masuk

Kod saya berfungsi untuk contoh pertama tetapi memberikan output yang salah untuk contoh kedua. Saya menyahpenyahnya dan mendapati bahawa kaedah yang saya gunakan adalah salah. Apakah cara yang betul untuk menyelesaikan masalah ini?

Penyelesaian

Kami boleh mencari secara rekursif semua cara yang mungkin untuk mengira jumlah gcd. Apa nak buat?

Jika tatasusunan mengandungi hanya dua elemen, kita boleh mengembalikan gcd dua elemen ini sahaja.

Jika ia mengandungi lebih banyak, mari kita ulangi semua pasangan nilai. Untuk setiap pasangan, kami mengira gcdnya, dan kami juga memanggil fungsi kami secara rekursif dengan salinan tatasusunan dengan kedua-dua nilai dialih keluar. Jika kami menambah hasil kedua-dua pengiraan, kami mendapat jumlah gcd untuk pasangan nilai yang dipilih pada masa ini.

Kini kami hanya menjejaki gcd terbaik yang ditemui setakat ini dan mengembalikannya pada penghujungnya.

Ini adalah kod yang (sepatutnya) melakukan perkara itu.

int solve(int[] ar) {
  // if we have only two elements, there's not much else we can do.
  if(ar.length == 2) {
    return gcd(ar[0], ar[1]);
  }

  //keep track of the largest gcd
  int best = 0;
  
  // for every pair of values in the array
  //  make a copy of the array without the pair and call recursively
  for(int i = 0; i < ar.length; i++) {
    for(int j = i + 1; j < ar.length; j++) {
      
      int score = gcd(ar[i], ar[j]);
      
      // make a copy
      int[] ar2 = new int[ar.length - 2];
      int copy_k = 0;
      for(int k=0; k < ar.length; k++) {
        // skip values that we already visited
        if(k == i || k == j) {
          continue;
        }
        
        ar2[copy_k] = ar[k];
        copy_k += 1;
      }
      
      // call recursively
      score += solve(ar2);
      
      if(score > best) // we found a better pair
        best = score;
    }
  }
  
  return best;
}
Salin selepas log masuk

Algoritma ini agak perlahan. Jika anda perlu mempercepatkan, terdapat sekurang-kurangnya dua bidang yang boleh anda perbaiki:

  • Mengira gcd adalah operasi yang mahal. Prapengiraan gcd semua kemungkinan pasangan nilai unik dan menyimpannya dalam peta cincang akan menghapuskan pengiraan berganda.
  • Ia menyemak beberapa pilih atur yang mungkin beberapa kali. (cth. memilih pasangan pertama dan kemudian pasangan kedua pada rekursi seterusnya adalah sama seperti memilih pasangan kedua dan kemudian pasangan pertama) Saya mempunyai beberapa idea yang tidak jelas tentang cara menyelesaikan masalah ini, tetapi sudah terlambat malam ini, Harap maaf . < /em>

Kemungkinan besar terdapat algoritma yang lebih pantas, itu hanya idea saya.

Editor: Nah, selepas tidur sebentar, saya tiba-tiba faham. Jika kita meninggalkan gelung luar semasa membuat pasangan, kita tidak akan mendapat sebarang pengisihan pendua pasangan. Pada asasnya hanya gantikan i dengan 0 di mana-mana sahaja, seperti ini:

for(int j = 1; j < ar.length; j++) {
    
  int score = gcd(ar[0], ar[j]);
  
  // Make a copy
  int[] ar2 = new int[ar.length - 2];
  int copy_k = 0;
  for(int k=1; k < ar.length; k++) {
    // Skip values that we already visited
    if(k == j) {
      continue;
    }
    
    ar2[copy_k] = ar[k];
    copy_k += 1;
  }
}

Salin selepas log masuk

Atas ialah kandungan terperinci Cari pasangan GCD untuk tatasusunan yang diberikan. 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

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

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)

Apakah sepuluh platform perdagangan mata wang maya? Apakah sepuluh platform perdagangan mata wang maya? Feb 20, 2025 pm 02:15 PM

Dengan populariti kriptografi, platform perdagangan mata wang maya telah muncul. Sepuluh platform perdagangan mata wang maya teratas di dunia disenaraikan seperti berikut mengikut jumlah transaksi dan bahagian pasaran: Binance, Coinbase, FTX, Kucoin, Crypto.com, Kraken, Huobi, Gate.io, Bitfinex, Gemini. Platform ini menawarkan pelbagai perkhidmatan, dari pelbagai pilihan cryptocurrency untuk perdagangan derivatif, sesuai untuk peniaga yang berbeza -beza.

Cara menyesuaikan pertukaran terbuka bijan ke dalam bahasa Cina Cara menyesuaikan pertukaran terbuka bijan ke dalam bahasa Cina Mar 04, 2025 pm 11:51 PM

Bagaimana cara menyesuaikan pertukaran terbuka bijan ke bahasa Cina? Tutorial ini merangkumi langkah -langkah terperinci mengenai komputer dan telefon bimbit Android, dari penyediaan awal hingga proses operasi, dan kemudian menyelesaikan masalah biasa, membantu anda dengan mudah menukar antara muka pertukaran terbuka ke Cina dan cepat memulakan dengan platform perdagangan.

Adakah saya perlu menggunakan Flexbox di tengah gambar bootstrap? Adakah saya perlu menggunakan Flexbox di tengah gambar bootstrap? Apr 07, 2025 am 09:06 AM

Terdapat banyak cara untuk memusatkan gambar bootstrap, dan anda tidak perlu menggunakan Flexbox. Jika anda hanya perlu berpusat secara mendatar, kelas pusat teks sudah cukup; Jika anda perlu memusatkan elemen secara menegak atau berganda, Flexbox atau Grid lebih sesuai. Flexbox kurang serasi dan boleh meningkatkan kerumitan, manakala grid lebih berkuasa dan mempunyai kos pengajian yang lebih tinggi. Apabila memilih kaedah, anda harus menimbang kebaikan dan keburukan dan memilih kaedah yang paling sesuai mengikut keperluan dan keutamaan anda.

10 platform perdagangan cryptocurrency teratas, sepuluh aplikasi platform perdagangan mata wang yang disyorkan 10 platform perdagangan cryptocurrency teratas, sepuluh aplikasi platform perdagangan mata wang yang disyorkan Mar 17, 2025 pm 06:03 PM

Sepuluh platform perdagangan cryptocurrency teratas termasuk: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6. Coinbase, 7. Kucoin, 8 crypto.com, 9. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

Cara Mengira C-SubScript 3 Subscript 5 C-SubScript 3 Subscript 5 Algoritma Tutorial Cara Mengira C-SubScript 3 Subscript 5 C-SubScript 3 Subscript 5 Algoritma Tutorial Apr 03, 2025 pm 10:33 PM

Pengiraan C35 pada dasarnya adalah matematik gabungan, yang mewakili bilangan kombinasi yang dipilih dari 3 dari 5 elemen. Formula pengiraan ialah C53 = 5! / (3! * 2!), Yang boleh dikira secara langsung oleh gelung untuk meningkatkan kecekapan dan mengelakkan limpahan. Di samping itu, memahami sifat kombinasi dan menguasai kaedah pengiraan yang cekap adalah penting untuk menyelesaikan banyak masalah dalam bidang statistik kebarangkalian, kriptografi, reka bentuk algoritma, dll.

10 platform perdagangan mata wang maya teratas 2025 Aplikasi Perdagangan Cryptocurrency Kedudukan Sepuluh Teratas 10 platform perdagangan mata wang maya teratas 2025 Aplikasi Perdagangan Cryptocurrency Kedudukan Sepuluh Teratas Mar 17, 2025 pm 05:54 PM

Sepuluh Platform Perdagangan Mata Wang Maya 2025: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6 Coinbase, 7. Kucoin, 8. Crypto.com, 9. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

Apakah platform mata wang digital yang selamat dan boleh dipercayai? Apakah platform mata wang digital yang selamat dan boleh dipercayai? Mar 17, 2025 pm 05:42 PM

Platform mata wang digital yang selamat dan boleh dipercayai: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6 Coinbase, 7. Kucoin, 8 crypto.com, 9. Bitfinex, 10. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.

Aplikasi Perisian Mata Wang Maya Selamat yang Disyorkan Top 10 Aplikasi Perdagangan Mata Wang Digital Ranking 2025 Aplikasi Perisian Mata Wang Maya Selamat yang Disyorkan Top 10 Aplikasi Perdagangan Mata Wang Digital Ranking 2025 Mar 17, 2025 pm 05:48 PM

Disyorkan Aplikasi Perisian Mata Wang Maya Selamat: 1. Okx, 2. Binance, 3. Gate.io, 4. Kraken, 5. Huobi, 6. Coinbase, 7. Kucoin, 8 crypto.com, 9. Bitfinex, 10. Keselamatan, kecairan, yuran pengendalian, pemilihan mata wang, antara muka pengguna dan sokongan pelanggan harus dipertimbangkan ketika memilih platform.