分数矩阵运算类
1.课题阐述
分数矩阵运算类:设计矩阵类和分数类,封装矩阵和分数的运用。
目的:掌握面向对象的程序设计思想,运用C#语言的继承-封装-重载-泛型,完成从数学算法到OOP实践。
要求:
(1)设计矩阵类Matrix,重载运算符+,-,,/,==,!=,~(转置),进行矩阵的运算和判断。进而能够完成方程组求解测试。
(2)设计分数类Rational,重载+,-,,/,==,!=,>(等比较),完成分数的运算和判断。
(3)通过泛型,实现具备分数计算能力的矩阵运算。
(4)每个类具备较直观的输出功能。
2.思路和方法
- 理论基础
分数类型Rational的加减乘除运算,矩阵的相加相乘转置,可逆运算规律,泛型的应用,重载重写的应用,格式化处理字符串,重写字符输出的函数,dynamic弱类型,矩阵运算时的异常处理 - 算法分析
设计分数类的时候,构造函数时使用辗转相除法求得分子和分母的最大公因数,实现化简约分;求可逆的时候,采用的是化增广矩阵为单位矩阵的方法,由于可逆矩阵一定和单位矩阵等价,把所给矩阵化成单位矩阵后,增广矩阵的后一部分就是所求矩阵的逆矩阵。 - 设计流程
先设计分数类,实现加减乘除和逻辑比较运算、重载运算符、重写Tostring()方法,以分子/分母的格式输出;
再设计矩阵类,实现加减乘除和求逆和转置运算,重载运算符,重写Tostring()方法,以按行按列的格式输出。
最后设置一系列的异常处理。
3.完成情况
可以实现矩阵加减乘等基本运算,如下图所示:
5.附件:关键源码
public string ToString(string format){
var res = "";
for (int row = 0; row < Data.GetLength(0); row++){
for (int col = 0; col < Data.GetLength(1); col++){
dynamic v1 = string.Format(format, Data[row, col]);
if (col == 0) res = res + '[' + v1 + ',';
else if (col == Data.GetLength(1) - 1) {
res = res + v1 + ']'; }
else {
res = res + v1 + ','; }
}
res += "\n";
}
return res;
}
public static Matrix<T> operator +(Matrix<T> M1, Matrix<T> M2){
if (M1.Data.GetLength(0) == M2.Data.GetLength(0) && M2.Data.GetLength(1<