C LANGUAGE TECHNOLOGY

【C言語】四捨五入,切り捨て,切り上げする標準ライブラリ関数と自作関数

悩んでいる人

C言語で四捨五入,切り捨て,切り上げする標準ライブラリ関数と自作関数を教えて!

こういった悩みにお答えします.

本記事の信頼性

  • リアルタイムシステムの研究歴12年.
  • 東大教員の時に,英語でOSの授業.
  • 2012年9月~2013年8月にアメリカのノースカロライナ大学チャペルヒル校コンピュータサイエンス学部2021年の世界大学学術ランキングで20位)で客員研究員として勤務.C言語でリアルタイムLinuxの研究開発
  • プログラミング歴15年以上,習得している言語: C/C++,Java,Python,Ruby,HTML/CSS/JS/PHP,MATLAB,Assembler (x64,ARM).
  • 東大教員の時に,C++言語で開発した「LLVMコンパイラの拡張」,C言語で開発した独自のリアルタイムOS「Mcube Kernel」GitHubにオープンソースとして公開

こういった私から学べます.

四捨五入,切り捨て,切り上げ

四捨五入とは,数値計算における端数処理の1つです.

ある桁までの値がほしい時は,その下の桁が4以下なら切り捨て,5以上なら切り上げます.

切り捨ては,その下の桁を0にします.

これに対して,切り上げは,その下の桁を0にするだけでなく,1つ上の桁を1加算します.

下表に整数に変換する場合(小数点第1位)の四捨五入,切り捨て,切り上げの例をまとめました.

数値の例四捨五入切り捨て切り上げ
0.5101
-2.6-3-3-2

C言語で四捨五入,切り捨て,切り上げする標準ライブラリ関数

C言語の四捨五入,切り捨て,切り上げする標準ライブラリ関数を紹介していきます.

round/roundf/roundl関数で四捨五入

round/roundf/roundl関数は,最も近い整数値に丸める(2つの整数の中間値の場合は0から遠い方に丸める)ように四捨五入した結果を返す関数です.

round/roundf/roundl関数の利用例は以下のコードです.

実行結果は以下になります.

floor/floorf/floorl関数で切り捨て

floor/floorf/floorl関数は引数を越えない最大の整数値を返す関数です.

floor/floorf/floorl関数の利用例は以下のコードです.

実行結果は以下になります.

ceil/ceilf/ceill関数で切り上げ

ceil/ceilf/ceill関数は,引き数を下回らない最小の整数値を返す関数です.

ceil/ceilf/ceill関数の利用例は以下のコードです.

実行結果は以下になります.

C言語で四捨五入,切り捨て,切り上げする自作関数

C言語で四捨五入,切り捨て,切り上げする自作関数と,小数第n位を四捨五入,切り捨て,切り上げする自作関数を紹介します.

myround/myroundf/myroundl関数で四捨五入

myround/myroundf/myroundl関数で四捨五入するコードは以下になります.

実行結果は以下になります.

myround_n/myroundf_n/myroundl_n関数で小数第n位を四捨五入

myround_n/myroundf_n/myroundl_n関数で小数第n位を四捨五入します(第2引数に指定).

myround_n/myroundf_n/myroundl_n関数を利用するコードは以下になります.

実行結果は以下になります.

myfloor/myfloorf/myfloorl関数で切り捨て

myfloor/myfloorf/myfloorl関数で切り捨てるコードは以下になります.

実行結果は以下になります.

myfloor_n/myfloorf_n/myfloorl_n関数で小数第n位を切り捨て

myfloor_n/myfloorf_n/myfloorl_n関数で小数第n位を四捨五入します(第2引数に指定).

myfloor_n/myfloorf_n/myfloorl_n関数を利用するコードは以下になります.

実行結果は以下になります.

myceil/myceilf/myceill関数で切り上げ

myceil/myceilf/myceill関数で切り上げるコードは以下になります.

実行結果は以下になります.

myceil_n/myceilf_n/myceill_n関数で小数第n位を切り上げ

myceil_n/myceilf_n/myceill_n関数で小数第n位を切り上げます(第2引数に指定).

myceil_n/myceilf_n/myceill_n関数で小数第n位を切り上げるコードは以下になります.

実行結果は以下になります.

まとめ

C言語で四捨五入,切り捨て,切り上げする標準ライブラリ関数と自作関数,小数第n位を四捨五入,切り捨て,切り上げする自作関数を紹介しました.

四捨五入,切り捨て,切り上げするコードを書きたい時の参考にして下さい.

C言語を独学で習得することは難しいです.

私にC言語の無料相談をしたいあなたは,公式LINE「ChishiroのC言語」の友だち追加をお願い致します.

友だち追加

独学が難しいあなたは,C言語を学べるおすすめのオンラインプログラミングスクール3社で自分に合うスクールを見つけましょう.

-C LANGUAGE, TECHNOLOGY
-, , , , , , , , ,

S