Rumah > pembangunan bahagian belakang > C++ > Bagaimanakah Saya Boleh Mencipta Fungsi Pembundaran Titik Terapung Tersuai dalam C ?

Bagaimanakah Saya Boleh Mencipta Fungsi Pembundaran Titik Terapung Tersuai dalam C ?

Linda Hamilton
Lepaskan: 2024-12-29 00:01:11
asal
297 orang telah melayarinya

How Can I Create a Custom Floating-Point Rounding Function in C  ?

Fungsi Pembundaran Titik Terapung Tersuai

C tidak termasuk fungsi pusingan() terbina dalam untuk nilai titik terapung. Walau bagaimanapun, adalah mungkin untuk mencipta fungsi anda sendiri menggunakan kaedah floor():

double round(double d)
{
  return floor(d + 0.5);
}
Salin selepas log masuk

Pelaksanaan ini menyediakan pembundaran separuh ke atas, seperti yang dinyatakan dalam keperluan:

round(0.1) = 0
round(-0.1) = 0
round(-0.9) = -1
Salin selepas log masuk

Nota Pelaksanaan

Adalah penting untuk ambil perhatian bahawa pelaksanaan ini tidak sempurna dan mempunyai beberapa had:

  • Ia tidak mengendalikan pembundaran nilai yang hampir dengan titik tengah (cth., pusingan(0.5) akan mengembalikan 0 dan bukannya 1).
  • Ia mungkin tidak tepat untuk besar atau nilai kecil kerana ketepatan titik terapung pengehadan.

Alternatif

Untuk pelaksanaan pembundaran yang lebih mantap, pertimbangkan untuk menggunakan perpustakaan luaran atau fungsi std::round yang lebih baharu yang diperkenalkan dalam C 11.

Atas ialah kandungan terperinci Bagaimanakah Saya Boleh Mencipta Fungsi Pembundaran Titik Terapung Tersuai dalam C ?. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

sumber:php.cn
Kenyataan Laman Web ini
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
Artikel terbaru oleh pengarang
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan