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
Linda Hamiltonasal
2024-12-29 00:01:11322semak imbas

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);
}

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

round(0.1) = 0
round(-0.1) = 0
round(-0.9) = -1

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!

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