


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):
- Saya melakukannya menggunakan fungsi Math.sqrt() terbina dalam, tetapi saya ingin tahu jika ada cara untuk melakukannya menggunakan medan integer , dengan itu meningkatkan kelajuan.
- 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:
long tst = (long)(Math.sqrt(n) 0.5); 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.
jika (n return false;
return tst*tst == n;
}
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!

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

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

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

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]

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

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,

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

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


Alat AI Hot

Undresser.AI Undress
Apl berkuasa AI untuk mencipta foto bogel yang realistik

AI Clothes Remover
Alat AI dalam talian untuk mengeluarkan pakaian daripada foto.

Undress AI Tool
Gambar buka pakaian secara percuma

Clothoff.io
Penyingkiran pakaian AI

AI Hentai Generator
Menjana ai hentai secara percuma.

Artikel Panas

Alat panas

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Penyesuai Pelayan SAP NetWeaver untuk Eclipse
Integrasikan Eclipse dengan pelayan aplikasi SAP NetWeaver.

VSCode Windows 64-bit Muat Turun
Editor IDE percuma dan berkuasa yang dilancarkan oleh Microsoft

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)