Rumah >pembangunan bahagian belakang >Tutorial Python >Bagaimana Mencari Akar Kiub Integer Terbesar Kurang Daripada Ambang Menggunakan Python?

Bagaimana Mencari Akar Kiub Integer Terbesar Kurang Daripada Ambang Menggunakan Python?

Mary-Kate Olsen
Mary-Kate Olsenasal
2024-11-19 11:37:031058semak imbas

How to Find the Largest Integer Cube Root Less Than a Threshold Using Python?

Mencari Akar Kubus Integer Terbesar Kurang daripada Ambang

Dalam coretan kod ini, matlamatnya adalah untuk menentukan punca kubus terbesar iaitu nombor bulat kurang daripada 12,000. Kod ini menggunakan gelung sementara untuk mengurangkan pembolehubah n sehingga syarat dipenuhi.

Syarat dinyatakan sebagai n ** (1/3) ==, di mana kita ingin menyemak sama ada keputusan mengambil punca kubus bagi n ialah integer. Walau bagaimanapun, persoalan timbul tentang cara melakukan semakan ini.

Menyemak sama ada Float ialah Integer

Untuk menentukan sama ada nilai apungan ialah integer, Python menyediakan kaedah float.is_integer(). Kaedah ini mengembalikan True jika float ialah integer, dan False sebaliknya.

Menggunakan Kaedah float.is_integer()

Mengubah suai kod kami untuk menggabungkan float.is_integer () kaedah, kita ada:

processing = True
n = 12000
while processing:
    n -= 1
    if n ** (1/3).is_integer():
        processing = False

Perakaunan untuk Ketaktepatan Titik Terapung

Adalah penting untuk ambil perhatian bahawa aritmetik titik terapung boleh menjadi tidak tepat. Oleh itu, kita harus berhati-hati apabila membandingkan apungan untuk kesaksamaan.

Menyemak Nilai Berdekatan dengan Nombor Bulat

Jika kita bandingkan terus n ** (1/3) dengan integer, kita mungkin terlepas anggaran hampir kerana ketidaktepatan. Satu pendekatan adalah untuk menyemak sama ada punca kubus berada dalam julat kecil integer, menggunakan fungsi math.iclose atau pelaksanaan tersuainya.

Atas ialah kandungan terperinci Bagaimana Mencari Akar Kiub Integer Terbesar Kurang Daripada Ambang Menggunakan Python?. 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