weixin_45631165 2019-10-17 21:46 采纳率: 81.8%
浏览 336

一元二次方程相关问题,求大佬解答?

include

include

include

void f(double i, double j)
{
printf("i = ");
scanf_s("%d", &j);
}
int main(void)
{
double a = 0, b = 0, c = 0;
double A = 0, B = 0, C = 0;
double delta = 0;
double x1 = 0, x2 = 0;
char ch =0;
printf("请输入一元二次方程的三个系数: \n");
f(a, A);
f(b, B);
f(c, C);
delta = (b*b) - (4 * a * c);
do
{
if (delta > 0)
{
x1 = ((-b) + sqrt(delta)) / (2 * a);
x2 = ((-b) - sqrt(delta)) / (2 * a);
printf("该方程有两个解,x1 =%lf,x2=%lf\n", x1, x2);
}
else if (delta == 0)
{
x1 = x2 = (-b) / (2 * a);
printf("该方程有且只有一个解,x1 =x2 =%lf\n", x1);
}
else
printf("该方程没有实数解\n");
printf("请问是否需要继续(y/n): \n");
scanf_s(" %c", ch);
} while ("ch = y" || "ch = Y");
system("pause");
return 0;
}

图片说明

当在黑框中输入y时出现:缓冲区不等于nullptr? 请问这是什么意思啊
我这应该怎么改一下?

图片说明
图片说明

  • 写回答

2条回答 默认 最新

  • threenewbee 2019-10-17 22:46
    关注
    void f(double i, double j)
    {
    printf("i = ");
    scanf_s("%d", &j);
    }
    ->
    void f(double* j)
    {
    scanf_s("%lf", j);
    }
    主程序
    f(&a);
    f(&b);
    f(&c);
    
    评论

报告相同问题?

悬赏问题

  • ¥20 关于#硬件工程#的问题,请各位专家解答!
  • ¥15 关于#matlab#的问题:期望的系统闭环传递函数为G(s)=wn^2/s^2+2¢wn+wn^2阻尼系数¢=0.707,使系统具有较小的超调量
  • ¥15 FLUENT如何实现在堆积颗粒的上表面加载高斯热源
  • ¥30 截图中的mathematics程序转换成matlab
  • ¥15 动力学代码报错,维度不匹配
  • ¥15 Power query添加列问题
  • ¥50 Kubernetes&Fission&Eleasticsearch
  • ¥15 報錯:Person is not mapped,如何解決?
  • ¥15 c++头文件不能识别CDialog
  • ¥15 Excel发现不可读取的内容