Dalam pengaturcaraan, fungsi pow() digunakan untuk mengira eksponen bagi suatu nombor. Walau bagaimanapun, dalam senario tertentu, ia boleh mengembalikan hasil yang tidak dijangka. Mari kita periksa kes pow(5,2) mengembalikan 24.
Dalam kod yang anda berikan, fungsi pow() mengambil dua hujah integer: number1 dan number2. Ia menilai nombor1 yang dinaikkan kepada kuasa nombor2 dan memberikan hasilnya kepada jawapan pembolehubah integer. Sebagai contoh, pow(5,2) sepatutnya menghasilkan 25.
Walau bagaimanapun, anda mendapati bahawa pow(5,2) sebaliknya mengembalikan 24. Ini berlaku kerana fungsi pow() dalam perpustakaan matematik C mengembalikan hasilnya sebagai nombor titik terapung berketepatan dua kali. Dalam kes ini, keputusan sebenar mungkin hampir 25, tetapi disebabkan had ketepatan dalam aritmetik titik terapung, ia mungkin tersasar sedikit.
Untuk menyelesaikan isu ini, anda boleh menggunakan teknik yang dipanggil " pembundaran" untuk menukar secara eksplisit hasil titik terapung kepada integer. Satu kaedah untuk mencapai ini ialah dengan menggunakan fungsi ceil(), yang memastikan hasilnya dibundarkan ke integer terdekat.
Sebagai contoh, pengubahsuaian kod berikut akan membetulkan gelagat fungsi pow():
int answer; answer = ceil(pow(number1, number2));
Dengan memasukkan pengubahsuaian ini, anda boleh menjamin bahawa fungsi pow() menggambarkan dengan tepat operasi matematik bagi eksponen, memastikan pow(5,2) itu mengembalikan nilai jangkaan 25.
Atas ialah kandungan terperinci Mengapakah `pow(5,2)` Mengembalikan 24 Daripada 25?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!