JUMLAH DUA INTEGER - leetcode - Python
Jan 22, 2025 pm 04:11 PMMari kita sampai ke teras menambah dua integer tanpa menggunakan operator ' '. Ini memerlukan manipulasi binari.
Kami akan mendekati ini seperti penambahan biasa, tetapi menggunakan binari.
- Mula menambah dari kanan, seperti biasa anda lakukan: 1 1, 0 1, 1 0, 0 0.
- Memandangkan kami bekerja dalam binari, jika jumlahnya mencapai 2, tetapkan semula kepada 0 (1 1 = 10 binari, menjadi 0 dengan bawa).
- Ulangi ini untuk semua bit. Ini memberi kami jumlah separa, mengabaikan bawa buat masa ini.
Pengendali bitwise XOR (^) mengendalikan jumlah permulaan ini dengan sempurna:
- Jika bit adalah sama, hasilnya ialah 0. Jika ia berbeza, hasilnya ialah 1.
Ini sejajar dengan keperluan kami: 1 1 → 0 (dengan pembawa), 0 1 atau 1 0 → 1 dan 0 0 → 0.
Sekarang, mari kita atasi masalahnya. Pengendali DAN (&) membantu kami mencari mereka:
- Jika kedua-dua bit ialah 1, hasilnya ialah 1 (a carry).
Untuk mengalihkan pembawa ke kiri, kami akan menggunakan anjakan bit kiri.
Algoritma:
-
Permulaan:
-
sum = a ^ b
(XOR untuk jumlah tanpa bawa) -
carry = (a & b)
(DAN untuk dibawa)
-
-
Lelaran:
- Ulang sehingga
carry == 0
:a = sum
-
b = carry << 1
(anjakan bit kiri untuk dibawa)
- Ulang sehingga
Contoh (5 3):
- Nilai Awal:
- Lelaran 1:
sum = 0101 ^ 0011 = 0110
carry = 0101 & 0011 = 0001
- Lelaran 2:
sum = 0110 ^ 0010 = 0100
carry = 0110 & 0010 = 0010
- Lelaran 3:
sum = 0100 ^ 00100 = 0000
carry = 0100 & 0100 = 0100
- Lelaran 4:
sum = 0000 ^ 1000 = 1000
carry = 0000 & 1000 = 0000
Bawaan ialah 0, jadi jumlah akhir ialah 1000 (8).
Integer tanpa sempadan Python menyebabkan masalah dengan nombor negatif. Peralihan bit kiri boleh membawa kepada pertumbuhan yang tidak terhingga. Untuk membetulkannya, kita perlu mensimulasikan integer bersaiz tetap (cth., 32-bit).
Kami akan menggunakan topeng 32-bit (0xFFFFFFFF) untuk mengehadkan bilangan bit:
Ini memastikan bahawa hanya 32 bit terakhir dipertimbangkan, menghalang pertumbuhan yang tidak terhingga. Kami juga mengendalikan hasil negatif yang berpotensi dengan menukarnya kepada perwakilan pelengkap dua 32-bit mereka jika perlu.
Pendekatan ini secara berkesan mensimulasikan aritmetik integer 32-bit dalam Python, menyelesaikan isu dengan integer tidak terhad dan nombor negatif. Keadaan if a > MAX_INT
memastikan bahawa hasilnya kekal dalam julat integer bertanda 32-bit. Contoh dengan -12 dan -8 menunjukkan cara pembetulan ini berfungsi untuk menghasilkan hasil jangkaan -20.
Nama saya Jaimin Bariya, jika anda mendapati sesuatu yang berguna, sila like dan komen, dan ikuti saya di github jaimin-bariya
Atas ialah kandungan terperinci JUMLAH DUA INTEGER - leetcode - Python. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Artikel Panas

Alat panas Tag

Artikel Panas

Tag artikel panas

Notepad++7.3.1
Editor kod yang mudah digunakan dan percuma

SublimeText3 versi Cina
Versi Cina, sangat mudah digunakan

Hantar Studio 13.0.1
Persekitaran pembangunan bersepadu PHP yang berkuasa

Dreamweaver CS6
Alat pembangunan web visual

SublimeText3 versi Mac
Perisian penyuntingan kod peringkat Tuhan (SublimeText3)

Topik panas

Bagaimana saya menggunakan sup yang indah untuk menghuraikan html?

Cara Menggunakan Python untuk Mencari Pengagihan Zipf Fail Teks

Cara Bekerja Dengan Dokumen PDF Menggunakan Python

Cara Cache Menggunakan Redis dalam Aplikasi Django

Bagaimana untuk melakukan pembelajaran mendalam dengan Tensorflow atau Pytorch?

Cara Melaksanakan Struktur Data Anda Sendiri di Python

Serialization dan deserialisasi objek python: Bahagian 1
