冽栀 2021-11-26 22:43 采纳率: 80%
浏览 56
已结题

请看一下哪里错了,ax+by=c dx+ey=f

#include <stdio.h>
#include<math.h>
int main()
{
double a,b,c,d,e,f,x,y;
double det, det1, det2, ind1, ind2;
scanf("%f%f%f%f%f%f",&a,&b,&c,&d,&e,&f);
det=ae-bd;
det1=af-cd;
det2=ce-bf;
if(fabs(det)<1e-6)
if(fabs(det1)<1e-6)
{ind1=-b/a;
ind2=c/a;
printf("Infinite solution:x=%f*k+%f,k varies within R\n",ind1,ind2);}
else
printf("unsolvable\n");
else
{x=det2/det;
y=det1/det;
printf("x=%f,y=%f\n",x,y);}
return (0);
}

  • 写回答

1条回答 默认 最新

  • 关注

    double类型读取用%lf
    scanf("%f%f%f%f%f%f",&a,&b,&c,&d,&e,&f);这里的%f都改成%lf
    scanf这里改完就可以了,代码如下:

    #include <stdio.h>
    #include <math.h>
    int main()
    {
        double a,b,c,d,e,f,x,y;
        double det, det1, det2, ind1, ind2;
        scanf("%lf%lf%lf%lf%lf%lf",&a,&b,&c,&d,&e,&f);
    
        det=a*e-b*d;
        det1=a*f-c*d;
        det2=c*e-b*f;
        if(fabs(det)<1e-6)
            if(fabs(det1)<1e-6)
            {
                ind1=-b/a;
                ind2=c/a;
                printf("Infinite solution:x=%f*k+%f,k varies within R\n",ind1,ind2);
            }
            else
                printf("unsolvable\n");
        else
        {
            x=det2/det;
            y=det1/det;
            printf("x=%f,y=%f\n",x,y);
        }
        return (0);
    }
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论 编辑记录

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 12月1日
  • 已采纳回答 11月26日
  • 修改了问题 11月26日
  • 修改了问题 11月26日
  • 展开全部

悬赏问题

  • ¥20 机器学习能否像多层线性模型一样处理嵌套数据
  • ¥20 西门子S7-Graph,S7-300,梯形图
  • ¥50 用易语言http 访问不了网页
  • ¥50 safari浏览器fetch提交数据后数据丢失问题
  • ¥15 matlab不知道怎么改,求解答!!
  • ¥15 永磁直线电机的电流环pi调不出来
  • ¥15 用stata实现聚类的代码
  • ¥15 请问paddlehub能支持移动端开发吗?在Android studio上该如何部署?
  • ¥20 docker里部署springboot项目,访问不到扬声器
  • ¥15 netty整合springboot之后自动重连失效