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 JVM menyumbang kepada kemampuan 'Write Once, Run, di mana -mana' Java?Bagaimanakah JVM menyumbang kepada kemampuan 'Write Once, Run, di mana -mana' Java?May 02, 2025 am 12:25 AM

JVM melaksanakan ciri-ciri Wora Java melalui tafsiran bytecode, API bebas platform dan pemuatan kelas dinamik: 1. Bytecode ditafsirkan sebagai kod mesin untuk memastikan operasi silang platform; 2. Perbezaan sistem operasi abstrak API standard; 3. Kelas dimuatkan secara dinamik pada masa runtime untuk memastikan konsistensi.

Bagaimanakah versi baru Java menangani isu-isu khusus platform?Bagaimanakah versi baru Java menangani isu-isu khusus platform?May 02, 2025 am 12:18 AM

Versi terbaru Java berkesan menyelesaikan masalah khusus platform melalui pengoptimuman JVM, penambahbaikan perpustakaan standard dan sokongan perpustakaan pihak ketiga. 1) Pengoptimuman JVM, seperti ZGC Java11 meningkatkan prestasi pengumpulan sampah. 2) Penambahbaikan perpustakaan standard, seperti sistem modul Java9 yang mengurangkan masalah berkaitan platform. 3) Perpustakaan pihak ketiga menyediakan versi yang dioptimumkan platform, seperti OpenCV.

Terangkan proses pengesahan bytecode yang dilakukan oleh JVM.Terangkan proses pengesahan bytecode yang dilakukan oleh JVM.May 02, 2025 am 12:18 AM

Proses pengesahan bytecode JVM termasuk empat langkah utama: 1) Periksa sama ada format fail kelas mematuhi spesifikasi, 2) mengesahkan kesahihan dan ketepatan arahan bytecode, 3) melakukan analisis aliran data untuk memastikan keselamatan jenis, dan 4) mengimbangi ketelitian dan prestasi pengesahan. Melalui langkah -langkah ini, JVM memastikan bahawa hanya selamat, bytecode yang betul dilaksanakan, dengan itu melindungi integriti dan keselamatan program.

Bagaimanakah kemerdekaan platform memudahkan penggunaan aplikasi Java?Bagaimanakah kemerdekaan platform memudahkan penggunaan aplikasi Java?May 02, 2025 am 12:15 AM

Java'splatformindependenceAllowsApplicationStoranyoperatingsystemwithajvm.1) singlecodebase: writeandcompileonceforallplatforms.2) Easyupdates: UpdateTecodeForsimulteUseUlyDeployment.3)

Bagaimanakah kemerdekaan platform Java berkembang dari masa ke masa?Bagaimanakah kemerdekaan platform Java berkembang dari masa ke masa?May 02, 2025 am 12:12 AM

Kemerdekaan platform Java terus dipertingkatkan melalui teknologi seperti JVM, kompilasi JIT, penyeragaman, generik, ekspresi Lambda dan Projectpanama. Sejak tahun 1990-an, Java telah berkembang dari JVM asas kepada JVM moden berprestasi tinggi, memastikan konsistensi dan kecekapan kod di platform yang berbeza.

Apakah beberapa strategi untuk mengurangkan isu khusus platform dalam aplikasi Java?Apakah beberapa strategi untuk mengurangkan isu khusus platform dalam aplikasi Java?May 01, 2025 am 12:20 AM

Bagaimanakah Java mengurangkan masalah khusus platform? Java melaksanakan platform bebas melalui JVM dan perpustakaan standard. 1) Gunakan bytecode dan JVM untuk abstrak perbezaan sistem operasi; 2) Perpustakaan standard menyediakan API silang platform, seperti laluan fail pemprosesan kelas Paths, dan pengekodan aksara pemprosesan kelas charset; 3) Gunakan fail konfigurasi dan ujian pelbagai platform dalam projek sebenar untuk pengoptimuman dan debugging.

Apakah hubungan antara kebebasan platform Java dan seni bina microservices?Apakah hubungan antara kebebasan platform Java dan seni bina microservices?May 01, 2025 am 12:16 AM

Java'splatformindependenceEnhancesMicroservicesarchitectureByOfferingDeploymentflexability, konsistensi, skalabilitas, andPortability.1) DeploymentflexabilityAllowsMicroserviceStorunonAnanyplatformWithAjvm.2) ConsistencyAcsServicSservicesSimpliesDevelanDanDevelan

Bagaimanakah GraalVM berkaitan dengan matlamat kemerdekaan platform Java?Bagaimanakah GraalVM berkaitan dengan matlamat kemerdekaan platform Java?May 01, 2025 am 12:14 AM

GraalVM meningkatkan kemerdekaan platform Java dalam tiga cara: 1. 2. Persekitaran Runtime Bebas, menyusun program Java ke dalam fail boleh laku tempatan melalui GraalvmnativeImage; 3. Pengoptimuman Prestasi, Graal Compiler menjana kod mesin yang cekap untuk meningkatkan prestasi dan konsistensi program Java.

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

Dreamweaver CS6

Dreamweaver CS6

Alat pembangunan web visual

mPDF

mPDF

mPDF ialah perpustakaan PHP yang boleh menjana fail PDF daripada HTML yang dikodkan UTF-8. Pengarang asal, Ian Back, menulis mPDF untuk mengeluarkan fail PDF "dengan cepat" dari tapak webnya dan mengendalikan bahasa yang berbeza. Ia lebih perlahan dan menghasilkan fail yang lebih besar apabila menggunakan fon Unicode daripada skrip asal seperti HTML2FPDF, tetapi menyokong gaya CSS dsb. dan mempunyai banyak peningkatan. Menyokong hampir semua bahasa, termasuk RTL (Arab dan Ibrani) dan CJK (Cina, Jepun dan Korea). Menyokong elemen peringkat blok bersarang (seperti P, DIV),

Notepad++7.3.1

Notepad++7.3.1

Editor kod yang mudah digunakan dan percuma

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Penyesuai Pelayan SAP NetWeaver untuk Eclipse

Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

SublimeText3 versi Mac

SublimeText3 versi Mac

Perisian penyuntingan kod peringkat Tuhan (SublimeText3)