C言語で絶対値を計算するには,引数や戻り値の型に応じて以下の関数を使用します.
以下の関数はいずれも,指定された引数の絶対値を取得する関数です.
関数 | ヘッダ | 備考 | |
---|---|---|---|
int | abs(int j) | stdlib.h | |
long | labs(long j) | stdlib.h | |
long long | llabs(long long j) | stdlib.h | C99 |
double | fabs(double x) | math.h | |
float | fabsf(float x) | math.h | C99 |
long double | fabsl(long double x) | math.h | C99 |
intmax_t | imaxabs(intmax_t j) | inttypes.h | C99 |
以下にそれぞれの関数を用いて絶対値を修得するサンプルプログラムを示します.
/* header files */
#include <stdio.h>
#include <stdlib.h>
#include <math.h>
#include <complex.h>
#include <inttypes.h>
/* main */
int main(void) {
int intVal = -100;
long lngVal = -100L;
long long lnglngVal = -100LL;
double dblVal = -100.0;
float fltVal = -100.0;
long double lngdblVal = -100.0L;
intmax_t imaxVal = -100;
printf("abs = %d\n", abs(intVal));
printf("labs = %ld\n", labs(lngVal));
printf("llabs = %lld\n", llabs(lnglngVal));
printf("fabs = %.2f\n", fabs(dblVal));
printf("fabsf = %.2f\n", fabsf(fltVal));
printf("fabsl = %.2Lf\n", fabsl(lngdblVal));
printf("imaxabs = %jd\n", imaxabs(imaxVal));
return EXIT_SUCCESS;
}
サンプルプログラムの実行結果は以下のようになります.
abs = 100 labs = 100 llabs = 100 fabs = 100.00 fabsf = 100.00 fabsl = 100.00 imaxabs = 100
たくさんあるC言語関連の書籍の中でも特に役に立った本です.よかったら参考にしてみてください.
C言語の実践的参考書.少々値段は張りますが初心者を脱しようとしている人は絶対に読むべきです.
文法だけでなく,コーディングスタイルやデバッグなど文字通り「実践的」なことが書かれているので非常にためになります.
オライリーの本は,読みにくい本が多いのですが本書はとても読みやすくオススメです.
ポインタの解説書としては最高の書籍です.
この1冊でポインタを完全に理解することができます.全くの初学者が読むには敷居が高いですが,入門書を読み終えた後に読むと非常に有益です.