C#判断一个矩阵是否为对称矩阵及反称矩阵的方法
作者:北风其凉 发布时间:2023-04-04 10:55:23
标签:C#,矩阵
本文实例讲述了C#判断一个矩阵是否为对称矩阵及反称矩阵的方法。分享给大家供大家参考。具体如下:
1.判断对称矩阵
对任意i和j,有a[i,j]=a[j,i]
/// <summary>
/// 检查一个矩阵是否为对称矩阵
/// </summary>
/// <param name="matrix">矩阵</param>
/// <returns>true:是对称矩阵 false:不是对称矩阵</returns>
private static bool isSymmetric(double[][] matrix)
{
//矩阵没有元素的情况
if (matrix.Length == 0)
{
return true;
}
//合法性检查:1)matrix应为矩阵;2)matrix应为方阵
if (!isMatrix(matrix) || matrix.Length != matrix[0].Length)
{
throw new Exception("输入不合法");
}
//矩阵对称条件:对任意i,j有a[i,j]=a[j,i]
for (int i = 0; i < matrix.Length; i++)
{
for (int j = 0; j < i; j++)
{
if (matrix[i][j] != matrix[j][i])
{
return false;
}
}
}
return true;
}
2.判断反称矩阵
对任意i和j,有a[i,j]=-a[j,i]
/// <summary>
/// 检查一个矩阵是否为反称矩阵
/// </summary>
/// <param name="matrix">矩阵</param>
/// <returns>true:是反称矩阵 false:不是反称矩阵</returns>
private static bool isSkewSymmetric(double[][] matrix)
{
//矩阵没有元素的情况
if (matrix.Length == 0)
{
return true;
}
//合法性检查:1)matrix应为矩阵;2)matrix应为方阵
if (!isMatrix(matrix) || matrix.Length != matrix[0].Length)
{
throw new Exception("输入不合法");
}
//矩阵反称条件:对任意i,j有a[i,j]=-a[j,i]
for (int i = 0; i < matrix.Length; i++)
{
for (int j = 0; j <= i; j++)
{
if (matrix[i][j] != -matrix[j][i])
{
return false;
}
}
}
return true;
}
3.相关函数
/// <summary>
/// 判断一个二维数组是否为矩阵
/// </summary>
/// <param name="matrix">二维数组</param>
/// <returns>true:是矩阵 false:不是矩阵</returns>
private static bool isMatrix(double[][] matrix)
{
//空矩阵是矩阵
if (matrix.Length < 1) return true;
//不同行列数如果不相等,则不是矩阵
int count = matrix[0].Length;
for (int i = 1; i < matrix.Length; i++)
{
if (matrix[i].Length != count)
{
return false;
}
}
//各行列数相等,则是矩阵
return true;
}
4.函数调用示例
1)Main函数代码
static void Main(string[] args)
{
//测试矩阵1:matrix1
double[][] matrix1 = new double[][]
{
new double[] { 1, 2, 3 },
new double[] { 2, 1, 2 },
new double[] { 3, 2, 1 }
};
if (isSymmetric(matrix1)) { Console.WriteLine("matrix1 是对称矩阵"); }
else { Console.WriteLine("matrix1 不是对称矩阵"); }
if (isSkewSymmetric(matrix1)) { Console.WriteLine("matrix1 是反称矩阵"); }
else { Console.WriteLine("matrix1 不是反称矩阵"); }
//测试矩阵2:matrix2
double[][] matrix2 = new double[][]
{
new double[] { 0, 1, 2 },
new double[] { -1, 0, 1 },
new double[] { -2, -1, 0 }
};
if (isSymmetric(matrix2)) { Console.WriteLine("matrix2 是对称矩阵"); }
else { Console.WriteLine("matrix2 不是对称矩阵"); }
if (isSkewSymmetric(matrix2)) { Console.WriteLine("matrix2 是反称矩阵"); }
else { Console.WriteLine("matrix2 不是反称矩阵"); }
//测试矩阵3:matrix3
double[][] matrix3 = new double[][]
{
new double[] { 1, 2, 3 },
new double[] { 4, 5, 6 },
new double[] { 7, 8, 9 }
};
if (isSymmetric(matrix3)) { Console.WriteLine("matrix3 是对称矩阵"); }
else { Console.WriteLine("matrix3 不是对称矩阵"); }
if (isSkewSymmetric(matrix3)) { Console.WriteLine("matrix3 是反称矩阵"); }
else { Console.WriteLine("matrix3 不是反称矩阵"); }
Console.ReadLine();
}
2)示例运行结果
希望本文所述对大家的C#程序设计有所帮助。


猜你喜欢
- 简介 在Android中运用了很多机制,例如:广播、服务、数据库、通知、包……等等。什么是广播?Broadcast是一
- 做个网站的安卓客户端,用户安装到自己手机上,如果我出了新版本怎么办呢?要有版本更新功能。 本来版本检测最好可以自动进行。但如果每次开启程序,
- 实现的功能:默认情况下将扫描整个项目的文件可以使用@ComponentScan注解配置扫描路径只将被@Component注解修饰的类装载到容
- Java super关键字super 关键字与 this 类似,this 用来表示当前类的实例,super 用来表示父类。super 可以用
- 前言:本篇文章将介绍Java多线程中的几个典型案例之单例模式,所谓单例模式,就是一个类只有一个实例对象,本文将着重介绍在多线程的背景下,单例
- 我就废话不多说了,大家还是直接看代码吧~package cn.nxl2018;class Test{ //十进制常量赋值 &n
- 最近做了很多项目,不同的系统,不同的部署方式,这里做个记录1.在jar包目录新建一个start.bat 文件,然后写入启动命令j
- @ApiModel使用场景在实体类上边使用,标记类时swagger的解析类概述提供有关swagger模型的其它信息,类将在操作中用作类型时自
- 有时候我们需要判断栈顶的应用是否是我们的应用,于是获取栈顶的应用包名的需求就出现了。在android5.0之前,系统提供了一套API可以实现
- 本文实例讲述了C#多线程之Thread中Thread.IsAlive属性用法。分享给大家供大家参考。具体如下:Thread.IsAlive属
- idea2019导入maven项目中的某些问题idea2019导入maven项目,会出现很多莫名其妙的问题,需要注意的是如果是idea201
- 这篇文章主要介绍了基于Java检查IPv6地址的合法性,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋
- IntelliJ IDEA最佳配置IntelliJ IDEA 分为两个版本:旗舰版(Ultimate)和社区版(Community)。旗舰版
- 写在前面jenkins作为java的好 * ,经历过单体项目时代->集群项目时代->容器集群分布式时代,使用稳定可靠,cpu友好(
- 经常坐地铁,却不知道地铁多少条线路?哪个站下车?今天就带领大家熟悉并绘制深圳地铁路线图。WPF在绘制矢量图方面有非常强大的优势,利用WPF可
- 什么是ByteBuddyByteBuddy是一个java的运行时代码生成库,他可以帮助你以字节码的方式动态修改java类的代码。为什么需要B
- C# 8.0中的模式匹配相对C# 7.0来说有了进一步的增强,对于如下类:class Point{ public
- 对话框(Dialog)是Android系统在Activity或者其他组件运行过程中提供的一种提示机制。它可以帮助应用完成一些必要的提示功能,
- 本文实例讲述了WinForm实现移除控件某个事件的方法,供大家参考借鉴一下。具体功能代码如下:主要功能部分代码如下:/// <summ
- 最近做了关于在Android设备上外接扫码的项目,在此记录一下关于Android USB扫码枪获取内容的问题首先我这边使用是USB HID的