分数矩阵运算类

分数矩阵运算类

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<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值