二元一次方程的问题
这是我根据论坛的朋友代码改写的,由于刚学习C,看不懂那位朋友写的,所以改写了,但x,y 结果不正确,请哪位高手指正下,非常感谢#include <stdio.h>
int main ()
{
/*
* a * x + b * y = c
* d * x + e * y = f
*/
double a,b,c, d,e,f;
printf("请从左至右依次输入第一方程式和第二方程式的系数,空格分开,回车结束。\n");
scanf ("%f %f %f %f %f %f",&a,&b,&c,&d,&e,&f);
/*
变形一下,消x
adx + bdy = cd
dax + eay = fa
一式子减二式消去x
(bd - ea)y = cd - fa
y = (cd - fa) / (bd - ea)
*/
double y = (c * d - f * a) / (b * d - e * a);
//带入y到第一个式子求x
doublex = (c - b * y ) / a;
printf("x=%0.2f y=%0.2f",x,y);
return 0;
} double输入要用%lf
#include <stdio.h>
int main ()
{
/*
* a * x + b * y = c
* d * x + e * y = f
*/
double a,b,c, d,e,f;
printf("请从左至右依次输入第一方程式和第二方程式的系数,空格分开,回车结束。\n");
scanf ("%lf %lf %lf %lf %lf %lf",&a,&b,&c,&d,&e,&f);
/*
变形一下,消x
adx + bdy = cd
dax + eay = fa
一式子减二式消去x
(bd - ea)y = cd - fa
y = (cd - fa) / (bd - ea)
*/
double y = (c * d - f * a) / (b * d - e * a);
//带入y到第一个式子求x
doublex = (c - b * y ) / a;
printf("x=%0.2f y=%0.2f",x,y);
return 0;
} 本帖最后由 傻眼貓咪 于 2022-1-21 09:01 编辑
楼上大佬已经解答。
这题好有趣,我想试试 C++:#include <bits/stdc++.h>
using namespace std;
typedef struct{
double a, b, c;
}Equation;
class Root{
public:
double m_x, m_y;
Root(const Equation(*), const Equation(*));
};
Root::Root(const Equation *A, const Equation *B){
double a = A->a, b = A->b, c = A->c;
double x = B->a, y = B->b, z = B->c;
m_x = (z * b - c * y) / (x * b - a * y);
m_y = (z - x * m_x) / y;
}
int main(){
Equation A = {1, 1, 5}; // x + y = 5
Equation B = {1, -1, 1}; // x - y = 1
Root res(&A, &B);
cout << setprecision(2) << "x: " << res.m_x << " y: " << res.m_y << endl;
return 0;
} 大马强 发表于 2022-1-20 22:55
double输入要用%lf
非常感谢 傻眼貓咪 发表于 2022-1-21 08:59
楼上大佬已经解答。
这题好有趣,我想试试 C++:
还看不懂,收藏了,将来备用,谢谢 我都不知道这样能求解{:10_256:}
学费了{:10_279:} {:10_257:}
页:
[1]