C#简单的矩阵类并实现基本的矩阵运算

在C#中,你可以通过创建自定义类或使用现有的库(如MathNet.Numerics)来实现矩阵计算。下面是一个简单的例子,说明如何创建一个简单的矩阵类并实现基本的矩阵运算。

首先,我们定义一个Matrix类来表示矩阵,并提供基本的矩阵操作,如加法、乘法和转置。

csharp 复制代码
using System;

public class Matrix
{
    private double[,] _values;

    public int Rows { get; }
    public int Cols { get; }

    public Matrix(int rows, int cols)
    {
        Rows = rows;
        Cols = cols;
        _values = new double[rows, cols];
    }

    public Matrix(double[,] values)
    {
        Rows = values.GetLength(0);
        Cols = values.GetLength(1);
        _values = (double[,])values.Clone();
    }

    public double this[int row, int col]
    {
        get { return _values[row, col]; }
        set { _values[row, col] = value; }
    }

    public static Matrix Add(Matrix a, Matrix b)
    {
        if (a.Rows != b.Rows || a.Cols != b.Cols)
        {
            throw new ArgumentException("Matrices must have the same dimensions to be added.");
        }

        Matrix result = new Matrix(a.Rows, a.Cols);
        for (int i = 0; i < a.Rows; i++)
        {
            for (int j = 0; j < a.Cols; j++)
            {
                result[i, j] = a[i, j] + b[i, j];
            }
        }
        return result;
    }

    public static Matrix Multiply(Matrix a, Matrix b)
    {
        if (a.Cols != b.Rows)
        {
            throw new ArgumentException("The number of columns of the first matrix must be equal to the number of rows of the second matrix.");
        }

        Matrix result = new Matrix(a.Rows, b.Cols);
        for (int i = 0; i < a.Rows; i++)
        {
            for (int j = 0; j < b.Cols; j++)
            {
                for (int k = 0; k < a.Cols; k++)
                {
                    result[i, j] += a[i, k] * b[k, j];
                }
            }
        }
        return result;
    }

    public Matrix Transpose()
    {
        Matrix result = new Matrix(Cols, Rows);
        for (int i = 0; i < Rows; i++)
        {
            for (int j = 0; j < Cols; j++)
            {
                result[j, i] = _values[i, j];
            }
        }
        return result;
    }

    public override string ToString()
    {
        string result = "";
        for (int i = 0; i < Rows; i++)
        {
            for (int j = 0; j < Cols; j++)
            {
                result += _values[i, j] + "\t";
            }
            result += Environment.NewLine;
        }
        return result;
    }
}

然后,你可以这样使用你的Matrix类:

csharp 复制代码
class Program
{
    static void Main(string[] args)
    {
        // 创建两个矩阵
        Matrix a = new Matrix(2, 2);
        a[0, 0] = 1;
        a[0, 1] = 2;
        a[1, 0] = 3;
        a[1, 1] = 4;

        Matrix b = new Matrix(2, 2);
        b[0, 0] = 5;
        b[0, 1] = 6;
        b[1, 0] = 7;
        b[1, 1] = 8;

        // 输出原始矩阵
        Console.WriteLine("Matrix A:");
        Console.WriteLine(a);
        Console.WriteLine("Matrix B:");
        Console.WriteLine(b);

        // 矩阵加法
        Matrix sum = Matrix.Add(a, b);
        Console.WriteLine("Sum of A and B:");
        Console.WriteLine
相关推荐
爱编程的小新☆1 分钟前
JAVA实现Manus智能体
java·react·cot·智能体·spring ai·manus·agent loop
用户3721574261355 分钟前
Java 如何插入和删除 Excel 行和列
java
@SmartSi7 分钟前
AgentScope Java 入门:如何使用 OpenAIChatModel 集成兼容 OpenAI 协议模型
java·agentscope
就叫_这个吧16 分钟前
Java线程池应用的四种方式+线程池底层实现原理
java·开发语言
Dicky-_-zhang18 分钟前
Java并发编程实战:线程池与并发工具类
java·jvm
devilnumber18 分钟前
JDK6→JDK7→JDK8 重点技术更新(精简背诵版)
java
云烟成雨TD19 分钟前
Spring AI Alibaba 1.x 系列【61】Graph 持久化执行
java·人工智能·spring
muqsen20 分钟前
Java 分布式相关面试题总结
java·开发语言·分布式
做个文艺程序员22 分钟前
第02篇:搭建 ES 集群 + Spring Boot 整合实战——从 Docker Compose 到 Java 客户端全覆盖
java·spring boot·elasticsearch
Jinkxs23 分钟前
LoadBalancer- 简单限流策略:Nginx 基于连接 / 请求的限流实现
java·运维·nginx