| 在做一道题,解一元二次方程,题目本身没什么难度,就不贴了 这个代码是网上找的,可以AC 附完整代码 
#include <stdio.h>
#include <math.h>
int main()
{
    double a, b, c;
    scanf("%lf%lf%lf", &a, &b, &c);
    if(!a && !b)
    {
        printf(c?"Not An Equation":"Zero Equation");
        return 0;
    }
    if(!a)
    {
        printf("%.2f", -c/b);
        return 0;
    }
    double delta = b*b - 4*a*c;
    if(delta == 0)
    {
        printf("%.2f", -b/2/a);
    }
    else if(delta > 0)
    {
        printf("%.2f\n%.2f", (-b+pow(delta, 0.5))/2/a, (-b-pow(delta, 0.5))/2/a);
    }
    else
    {
      if(b == 0)
        printf("%.2f+%.2fi\n%.2f-%.2fi", 0.00, pow(-delta, 0.5)/2/fabs(a), 0.00, pow(-delta, 0.5)/2/fabs(a));
      else
        printf("%.2f+%.2fi\n%.2f-%.2fi", -b/2/a, pow(-delta, 0.5)/2/fabs(a), -b/2/a, pow(-delta, 0.5)/2/fabs(a));
    }
    return 0;
}题目在这里http://www.patest.cn/contests/basic-programming/%E5%88%86%E6%94%AF-18 | |
| 
简单总结一下我的问题,应该就是:
 
if(b == 0)
  printf("%.2f", 0.00)
else
  printf("%.2f", -b/2/a)和 
  printf("%.2f", -b/2/a)这两段代码在什么情况下会不一样? | |
| 50分 | 
第一种方式,当b==0输出    0.00 第二种方式,当b==0输出 -0.00 | 
| 当然,a要是正数才有负号输出 | |
| 
double数值 不能跟0直接比较吧 一般不是用 |a-0| < 0.0000001 这种方式么? | |
| 
试试%.2g | |
| 25分 | 
计算机不会骗人,只会按照程序的意图去执行的。 楼主的这个问题的原因在于浮点数(float/double)的表示方法,按照IEEE754的标准,零是正零和负零的(-0.0, +0.0) 题目的意思要求 b==0的时候要按正零输出,这就是你所说的”结果就会有一个测试点通不过” 看下面的程序你就会明白了。 
#include <stdio.h>
#include <string.h>
int
main(int argc, char *argv[])
{
    int    i, n;
    char   s[sizeof(double)];
    double a = -1.0;
    double b = +1.0;
    n = sizeof(s);
    while (a != 0.0) {
        a = a / 2.0;
    }
    printf("a=%.2f\n", a);
    memcpy(s, &a, sizeof(s));
    for (i = 0; i < n; i++) {
        printf("%02x ", (unsigned char)s[i]);
    }
    printf("\n");
    while (b != 0.0) {
        b = b / 2.0;
    }
    printf("b=%.2f\n", b);
    memcpy(s, &b, sizeof(s));
    for (i = 0; i < n; i++) {
        printf("%02x ", (unsigned char)s[i]);
    }
    printf("\n");
    return 0;
}
/* 输出:
a=-0.00
00 00 00 00 00 00 00 80 
b=0.00
00 00 00 00 00 00 00 00 
*/a=-0.00 | 
| 
楼主的这个问题的原因在于浮点数(float/double)的表示方法,按照IEEE754的标准,零是区分正零和负零的(-0.0, +0.0) | |
| 25分 | #include <stdio.h>
#include <string.h>
int main(int argc, char *argv[]) {
    int    i, n;
    char   s[sizeof(double)];
    double a = -1.0;
    double b = +1.0;
    n = sizeof(s);
    while (a != 0.0) {
        a = a / 2.0;
    }
    printf("a=%.2g\n", a);
    memcpy(s, &a, sizeof(s));
    for (i = 0; i < n; i++) {
        printf("%02x ", (unsigned char)s[i]);
    }
    printf("\n");
    while (b != 0.0) {
        b = b / 2.0;
    }
    printf("b=%.2g\n", b);
    memcpy(s, &b, sizeof(s));
    for (i = 0; i < n; i++) {
        printf("%02x ", (unsigned char)s[i]);
    }
    printf("\n");
    return 0;
}
/* 输出:
a=0
00 00 00 00 00 00 00 80
b=0
00 00 00 00 00 00 00 00
*/
 | 
 
                    



