帮忙看看怎么做?不管怎么做都是错的?

有如下分段函数
F(x) = x^2 + 1 当x> 0时;
F(x) = -x 当x<0时;
F(x) = 100.0 当x=0时;
编程根据输入的不同x(x为实数),输出其对应的函数值,结果保留1位小数。

图片说明

#include <stdio.h>
int main()
{
    double x,y;
    while(scanf("%f",&x)!=EOF)
    {
    {
        if(x>0)
            y=x*x+1;
        else if(x<0)
            y=-x;
        else
            y=100.0;
    }
        printf("%.1f\n",y);
    }
        return 0;
}

当我输入的数字不带小数时,例如8,输出结果正常。但当我输入8.00时,输出了一个很不正常的数。
图片说明

#include <stdio.h>
int main()
{
    double x,y;
    while(scanf("%f",&x)!=EOF)
    {
    {
        if(x>0)
            y=x*x+1;
        else if(x<0)
            y=-x;
        else
            y=100.0;
    }
        printf("%.1f\n",y);
    }
        return 0;
}


但如果我将a和b的数据类型从double改为float时,结果就正常了,但是ACM结果仍然判断错误。应该怎样修改?

double应该用scanf("%lf",&x)

double要用%lf