cari
RumahJavajavaTutorialApakah Cara Terpantas untuk Menentukan sama ada Punca Kuasa Dua Integer ialah Integer?

What's the Fastest Way to Determine if the Square Root of an Integer is an Integer?

Cara terpantas untuk menentukan sama ada punca kuasa dua integer ialah integer

Penerangan Masalah

Saya sedang mencari cara terpantas Kaedah untuk menentukan sama ada integer panjang ialah kuasa dua sempurna (iaitu punca kuasa duanya ialah integer lain):


  1. Saya melakukannya menggunakan fungsi Math.sqrt() terbina dalam, tetapi saya ingin tahu jika ada cara untuk melakukannya menggunakan medan integer , dengan itu meningkatkan kelajuan.

  2. Adalah tidak praktikal untuk mengekalkan jadual carian (kerana terdapat lebih kurang 231.5 integer yang kuasa duanya kurang daripada 263).

Berikut ialah cara yang sangat mudah dan mudah yang saya lakukan sekarang:

{
jika (n

return false;

long tst = (long)(Math.sqrt(n) 0.5);
return tst*tst == n;
}

Nota: Saya menggunakan fungsi ini dalam banyak masalah Project Euler. Oleh itu, tidak akan ada sebarang penyelenggaraan pada kod ini pada masa hadapan. Dan pengoptimuman mikro ini sebenarnya boleh membuat perbezaan, kerana sebahagian daripada cabaran mengambil masa kurang daripada satu minit untuk menyelesaikan setiap algoritma, sedangkan fungsi ini perlu dipanggil berjuta-juta kali dalam beberapa masalah.


Saya telah mencuba penyelesaian yang berbeza untuk masalah ini:


  • Selepas ujian menyeluruh, saya mendapati bahawa menambah 0.5 pada keputusan Math.sqrt() adalah tidak perlu, sekurang-kurangnya pada mesin saya.

  • Punca kuasa dua songsang pantas adalah lebih pantas daripada Math.sqrt() tetapi memberikan hasil yang salah untuk n >= 410881. Walau bagaimanapun, seperti yang dicadangkan oleh BobbyShaftoe, kita boleh menggunakan penggodaman FISR untuk n
  • Kaedah Newton jauh lebih perlahan daripada Math.sqrt(). Ini mungkin kerana Math.sqrt() menggunakan sesuatu yang serupa dengan kaedah Newton, tetapi dilaksanakan dalam perkakasan dan oleh itu lebih pantas daripada di Java. Selain itu, kaedah Newton masih memerlukan penggunaan nombor titik terapung berketepatan ganda.
  • integer bertanda 64-bit positif), dan ia lebih perlahan daripada Math.sqrt().
  • Carian binari adalah lebih perlahan. Ini masuk akal, kerana carian binari memerlukan purata 16 pas untuk mencari punca kuasa dua nombor 64-bit.

  • Menurut ujian John, menggunakan pernyataan atau adalah lebih pantas daripada menggunakan suis dalam C, tetapi dalam Java dan C# nampaknya tiada perbezaan antara atau dan suis.

  • Saya juga cuba membuat jadual carian (sebagai tatasusunan statik peribadi 64 boolean). Kemudian, daripada menggunakan suis atau atau pernyataan, saya hanya akan mengatakan if(lookup[(int)(n&0x3F)]) { test } else return false;. Yang mengejutkan saya, ini (sedikit) lebih perlahan. Ini kerana sempadan tatasusunan disemak dalam Java.


Atas ialah kandungan terperinci Apakah Cara Terpantas untuk Menentukan sama ada Punca Kuasa Dua Integer ialah Integer?. 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
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

Artikel ini membincangkan pelaksanaan caching pelbagai peringkat di Java menggunakan kafein dan cache jambu untuk meningkatkan prestasi aplikasi. Ia meliputi persediaan, integrasi, dan faedah prestasi, bersama -sama dengan Pengurusan Dasar Konfigurasi dan Pengusiran PRA Terbaik

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

Kelas kelas Java melibatkan pemuatan, menghubungkan, dan memulakan kelas menggunakan sistem hierarki dengan bootstrap, lanjutan, dan pemuat kelas aplikasi. Model delegasi induk memastikan kelas teras dimuatkan dahulu, yang mempengaruhi LOA kelas tersuai

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

Artikel ini meneroka mengintegrasikan pengaturcaraan berfungsi ke dalam Java menggunakan ekspresi Lambda, API Streams, rujukan kaedah, dan pilihan. Ia menyoroti faedah seperti kebolehbacaan dan kebolehkerjaan kod yang lebih baik melalui kesimpulan dan kebolehubahan

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

Artikel ini membincangkan menggunakan JPA untuk pemetaan objek-relasi dengan ciri-ciri canggih seperti caching dan pemuatan malas. Ia meliputi persediaan, pemetaan entiti, dan amalan terbaik untuk mengoptimumkan prestasi sambil menonjolkan potensi perangkap. [159 aksara]

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

Artikel ini membincangkan menggunakan Maven dan Gradle untuk Pengurusan Projek Java, membina automasi, dan resolusi pergantungan, membandingkan pendekatan dan strategi pengoptimuman mereka.

Bagaimana saya menggunakan API Java's Nio (Input/Output Baru) untuk I/O yang tidak menyekat?Bagaimana saya menggunakan API Java's Nio (Input/Output Baru) untuk I/O yang tidak menyekat?Mar 11, 2025 pm 05:51 PM

Artikel ini menerangkan NIO API Java untuk I/O yang tidak menyekat, menggunakan pemilih dan saluran untuk mengendalikan pelbagai sambungan dengan cekap dengan satu benang. Ia memperincikan proses, faedah (skalabilitas, prestasi), dan potensi perangkap (kerumitan,

Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Bagaimanakah saya membuat dan menggunakan perpustakaan Java Custom (fail JAR) dengan pengurusan versi dan pergantungan yang betul?Mar 17, 2025 pm 05:45 PM

Artikel ini membincangkan membuat dan menggunakan perpustakaan Java tersuai (fail balang) dengan pengurusan versi dan pergantungan yang betul, menggunakan alat seperti Maven dan Gradle.

Bagaimana saya menggunakan API Soket Java untuk komunikasi rangkaian?Bagaimana saya menggunakan API Soket Java untuk komunikasi rangkaian?Mar 11, 2025 pm 05:53 PM

Artikel ini memperincikan API soket Java untuk komunikasi rangkaian, yang meliputi persediaan pelanggan-pelayan, pengendalian data, dan pertimbangan penting seperti pengurusan sumber, pengendalian ralat, dan keselamatan. Ia juga meneroka teknik pengoptimuman prestasi, i

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

AI Hentai Generator

AI Hentai Generator

Menjana ai hentai secara percuma.

Artikel Panas

R.E.P.O. Kristal tenaga dijelaskan dan apa yang mereka lakukan (kristal kuning)
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Tetapan grafik terbaik
2 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌
R.E.P.O. Cara Memperbaiki Audio Jika anda tidak dapat mendengar sesiapa
3 minggu yang laluBy尊渡假赌尊渡假赌尊渡假赌

Alat panas

SublimeText3 versi Cina

SublimeText3 versi Cina

Versi Cina, sangat mudah digunakan

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

VSCode Windows 64-bit Muat Turun

VSCode Windows 64-bit Muat Turun

Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)