1. 程式人生 > >求解三元一次方程組(C++)

求解三元一次方程組(C++)

三元 eas logs use -1 output ostream cti pau

/**
 * author:johnny zen
 * date:2017-09-20 11:19 
 * function:Calculate Ternary system of equations
 * notice:時間倉促,僅僅實現功能,方便使用,代碼質量不可參考!!! 
 */
#include<iostream>
using namespace std;

template<class T>
void input(T matrix[4][5]){
    cout<<"please input matrix element‘s data"<<endl;
    
for(int i = 1;i<4;i++){ for(int j=1;j<5;j++){ cin>>matrix[i][j]; } } cout<<"input ok"; } template<class T> void calc(T matrix[4][5]){ T base_D = matrix[1][1]*matrix[2][2]*matrix[3][3] + matrix[2][1]*matrix[3][2]*matrix[1][3] + matrix[3
][1]*matrix[1][2]*matrix[2][3];//計算行列式 base_D = base_D-(matrix[1][3]*matrix[2][2]*matrix[3][1] + matrix[1][1]*matrix[2][3]*matrix[3][2] + matrix[1][2]*matrix[2][1]*matrix[3][3]); if(base_D != 0){ T x_D = matrix[1][4]*matrix[2][2]*matrix[3][3] + matrix[2][4]*matrix[3][2]*matrix[1
][3] + matrix[3][4]*matrix[1][2]*matrix[2][3]; x_D = x_D-(matrix[1][3]*matrix[2][2]*matrix[3][4] + matrix[1][4]*matrix[2][3]*matrix[3][2] + matrix[1][2]*matrix[2][4]*matrix[3][3]); T y_D = matrix[1][1]*matrix[2][4]*matrix[3][3] + matrix[2][1]*matrix[3][4]*matrix[1][3] + matrix[3][1]*matrix[1][4]*matrix[2][3]; y_D = y_D-(matrix[1][3]*matrix[2][4]*matrix[3][1] + matrix[1][1]*matrix[2][3]*matrix[3][4] + matrix[1][4]*matrix[2][1]*matrix[3][3]); T z_D = matrix[1][1]*matrix[2][2]*matrix[3][4] + matrix[2][1]*matrix[3][2]*matrix[1][4] + matrix[3][1]*matrix[1][2]*matrix[2][4]; z_D = z_D-(matrix[1][4]*matrix[2][2]*matrix[3][1] + matrix[1][1]*matrix[2][4]*matrix[3][2] + matrix[1][2]*matrix[2][1]*matrix[3][4]); T x = x_D/base_D; T y = y_D/base_D; T z = z_D/base_D; cout<<"[ x:"<<x<<"; y:"<<y<<"; z:"<<z<<" ]"<<endl; }else{ cout<<"【無解】"; // return DBL_MIN; } } int main(){ double matrix[4][5] ; //三元一次方程組 input<double>(matrix); calc<double>(matrix); system("pause"); return 0; } /*
demo
2x-y+z=10; 3x+2y-z=16; x+6y-z=28; 2 -1 1 10 3 2 -1 16 1 6 -1 28 output:input ok[ x:4.18182; y:5.09091; z:6.72727 ] */

求解三元一次方程組(C++)