丸めずにCで小数点以下を切り捨てるにはどうすればよいですか?
たとえば、番号が4.48
それはただ表示されます4.4
%.1f
に丸める4.5
整数除算が切り捨てられ、丸められないという事実を (ab) 使用できます。
float original = 4.48;
int tmp = original * 10; // 44.8 truncated to 44
float truncated = tmp / 10.0; // 4.4
簡単な方法は次のとおりです。
printf("%.1f",trunc(x*10.0)/10.0);
コンパイラがC99をサポートしている場合は、以下を使用できるはずですtrunc()
。
float f = 4.56f;
f = truncf(f * 10.0) / 10.0;
これはうまくいくはずです
double d = 4.48;
d *= 10.;
int i = d;
d = (double) i / 10.;
float myval = 4.48;
float tr = ((int)(myval*10)) / 10.0;