#循环输入,每输入一个浮点数a(其中a≤10000),就输出a的绝对值,精确到小数点后两位。当没有任何输入时,结束程序。
解题思路:
1,精确到小数点后两位,格式打印为%.af表示打印十进制的浮点数,保留小数点a位。
2,绝对值实际上为大于等于0保持不变 ,小于0跟-1进行乘积取结果。可以直接用c语言math.h库中的fabs()
3,表达式或参数中的float类型都会被默认转换成double类型,所以在k&c中,printf中的所有float类型的参数仍自动转换成double类型
代码详解:
#include <stdio.h>
#include <math.h>
int main() {
double a;
while (scanf("%lf", &a) != EOF) {
printf("%.2lf\n", fabs(a));
// 表示long double类型
}
return 0;
}
#循环输入,每组输入为四个浮点数,分别代表两个点,即(x0,y0),(x1,y1)求输出这两个点之间的距离,精确到小数点后两位。当没有任何输入,结束程序。
解题思路:四个浮点数,可以用数据类型为double的数组来存储,开平方用math.h的sqrt函数,然后自己可以手写一个平方函数。最后输出要求精确小数点后两位为%.2f
代码详解:
#include <stdio.h>
#include <math.h>
double sqr(double i){
return i*i;
)
int main()
{
double a[2],b[2];
while(scanf("%lf %lf %lf %lf",&a[0],&a[1],&b[0],&b[1])!=EOF){
int ans=sqrt(sqr(b[0]-a[0])+sqr(b[1]-b[1]));
printf("%.2lf",ans);
}
return 0;
}