Rumah >pembangunan bahagian belakang >C++ >Mengapakah `pow(10, 5)` Kadangkala Mengembalikan 9999 dalam C ?
Dalam C , menggunakan pow(10, 5) untuk mengira 10 dinaikkan kepada kuasa 5 tin kadangkala menghasilkan nilai yang tidak dijangka sebanyak 9,999. Tingkah laku ini tidak konsisten dan boleh menyebabkan kekeliruan, seperti yang ditunjukkan dalam coretan kod berikut:
const int sections = 10; for (int t = 0; t < 5; t++) { int i = pow(sections, 5 - t - 1); cout << i << endl; }
Keluaran yang dijangkakan bagi kod ini ialah [10000, 1000, 100, 10, 1], tetapi ia sebenarnya menghasilkan [9999, 1000, 99, 10, 1].
Punca isu ini terletak pada perwakilan titik terapung pow(10.0, 5) dalam C . Apabila hasil pengiraan ini disimpan dalam pembolehubah titik terapung berketepatan dua, ia mungkin mengandungi bahagian pecahan. Apabila ia kemudiannya ditugaskan kepada pembolehubah integer, bahagian pecahan dipotong, menghasilkan nilai yang kurang sedikit daripada jawapan sebenar. Dalam kes ini, pow(10.0, 5) boleh diwakili secara dalaman sebagai 9999.9999999, yang akan dipotong kepada 9999 apabila ditugaskan kepada integer.
Untuk mengelakkan masalah ini, seseorang boleh menggunakan alternatif berikut:
Atas ialah kandungan terperinci Mengapakah `pow(10, 5)` Kadangkala Mengembalikan 9999 dalam C ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!