行列式(三):n阶行列式
1.数学定义
n阶行列式定义如下:

2.算法实现
函数名: GetValue()
功能:返回一个行列式的值
Private Function GetValue()
Dim gValue As Double
Dim tempResultList As New List(Of Array)
) As Integer '要进行全排列的序列
tempNumArray(i) = i
Next
GetFullPerm(tempNumArray, , tempResultList)
Dim temp As Double
Dim tempData() As Integer
temp =
tempData = tempResultList(i)
temp = temp * TableData(j, tempData(j))
Next
temp = Math.Pow(-, GetInverseNum(tempData)) * temp
gValue += temp
Next
Return gValue
End Function
3.完整的行列式类(determinant)
使用示例:
Dim d As New Determinant(3)
d.Item(1, 1) = 1
d.Item(2, 2) = 2
d.Item(3, 3) = 4
Console.write(d.value)
Public Class Determinant
Private TableData(,) As Double
Private RankLength As Integer
'行列式的阶
Public ReadOnly Property Rank()
Get
Return RankLength
End Get
End Property
'行列式第iRow行第iCol列的元素
Public Property Item(ByVal iRow As Integer, ByVal iCol As Integer)
Get
, iCol - )
End Get
Set(ByVal value)
TableData(iRow - , iCol - ) = value
End Set
End Property
Public ReadOnly Property value()
Get
Return GetValue()
End Get
End Property
Public Sub New(ByVal nRank As Integer)
, nRank - ) As Double
TableData = tempArray
RankLength = nRank
End Sub
'求行列式的值
Private Function GetValue()
Dim gValue As Double
Dim tempResultList As New List(Of Array)
) As Integer '要进行全排列的序列
tempNumArray(i) = i
Next
GetFullPerm(tempNumArray, , tempResultList)
Dim temp As Double
Dim tempData() As Integer
temp =
tempData = tempResultList(i)
temp = temp * TableData(j, tempData(j))
Next
temp = Math.Pow(-, GetInverseNum(tempData)) * temp
gValue += temp
Next
Return gValue
End Function
'全排列
Private Sub GetFullPerm(ByVal NumArray() As Integer, ByVal LeftIndex As Integer, ByRef Result As List(Of Array))
Dim temp As Integer
Then
) As Integer
NumArray.CopyTo(tempArray, )
Result.Add(tempArray)
Else
temp = NumArray(LeftIndex)
NumArray(LeftIndex) = NumArray(i)
NumArray(i) = temp '对换
GetFullPerm(NumArray, LeftIndex + , Result)
NumArray(i) = NumArray(LeftIndex)
NumArray(LeftIndex) = temp '还原对换
Next
End If
End Sub
'逆序数
Private Function GetInverseNum(ByVal NumArray() As Integer)
Next
Next
Return Num
End Function
End Class
行列式(三):n阶行列式的更多相关文章
- 基于上三角变换或基于DFS的行(列)展开的n阶行列式求值算法分析及性能评估
进入大一新学期,看完<线性代数>前几节后,笔者有了用计算机实现行列式运算的想法.这样做的目的,一是巩固自己对相关概念的理解,二是通过独立设计算法练手,三是希望通过图表直观地展现涉及的两种算 ...
- C#程序计算N阶行列式的值及N元一次方程组
C#程序计算N阶行列式的值及N元一次方程组 用了挺长时间自行完成了C#程序计算N阶行列式的值及N元一次方程组.由于自己没有在网上查阅其他资料,所以只能硬着头皮用最朴素的思想和基础的算法进行编程.在给出 ...
- n阶行列式计算----c语言实现(完结)
花了半天时间,写了这个n阶行列式计算的程序,应该算是比较优美吧,有很多地方多次做了优化,程序占用内存不是很大,要是说小吧,也不合适,因为里边有一个递归,而且递归的深度还比较深.时间复杂度具体没有细看, ...
- 线代: N阶行列式
线性变换 将 (x, y) 变成 (2 x + y, x - 3 y) 就叫做线性变换, 这就是矩阵乘法, 用于表示一切线性变换. 几何上看, 把平面上的每个点 (x, y) 都变到 (2 x + y ...
- TOJ4537: n阶行列式
4537: n阶行列式 Time Limit(Common/Java):1000MS/3000MS Memory Limit:65536KByteTotal Submit: 28 ...
- Herding(hdu4709)三点运用行列式求面积
Herding Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submis ...
- n阶行列式算法(c程序)
#include<stdio.h> #include<math.h> #define N 100 //N比输入的阶数大即可 int main() { int n,a[N][ ...
- 计算n阶行列式的模板
之前在学习计数问题的时候也在网上找了很多关于行列式的资料 但是发现很多地方都只介绍2\3阶的情况 一些论文介绍的方法又看不懂 然后就一直耽搁着 今天恰好出到这样的题目 发现标算的代码简介明了 还挺开心 ...
- n阶行列式计算
1.化为上下三角 该类型的矩阵.行列式在之前写过(https://www.cnblogs.com/wangzheming35/p/12906624.html),也建议记住这个行列式的结论. 当然不仅仅 ...
随机推荐
- hadoop使用问题
前提 环境 ubuntu 安装hadoop 已经有一段时间 1.启动的时候提示 Connection reset by peer 这个查看日志,里面有说 ssh里面某个文件的权限太大 这个ssh里修改 ...
- ArcEngine 无法嵌入互操作类型
说明: 在.net 4.0中,声明 IPoint point = new PointClass();会出现下面这个错误 错误 2 类型"ESRI.ArcGIS.Geometry.PointC ...
- [.net 面向对象程序设计进阶] (6) Lamda表达式(二) 表达式树快速入门
[.net 面向对象程序设计进阶] (6) Lamda表达式(二) 表达式树快速入门 本节导读: 认识表达式树(Expression Tree),学习使用Lambda创建表达式树,解析表达式树. 学习 ...
- 【摘选引用】在安全的SQL 密码也不过如此
SQL密码再安全也禁不住破解!!! http://www.sqlservercentral.com/articles/password+cracking/96540/ 备注:[摘选引用]是本人日常收集 ...
- [异常解决] ubuntu上安采用sudo启动的firefox,ibus输入法失效问题解决
采用sudo启动的应用是root权限的应用, ibus失效是因为ibus的初始配置采用user权限: 而root下运行的firefox输入法的配置还是停留在默认情况~ 解决方案是在shell下以roo ...
- js模版引擎handlebars.js实用教程——结束语
返回目录 有了这些功能,[ajax+json+Handlebars]替代[vo+el表达式]不成问题,新时代的曙光已经来临,最佳解决方案在此,您还等什么? 教程到此结束...祝读者学习愉快... 小菜 ...
- Linux下安装Apache并以mod_wsgi方式部署django站点
源码编译方式安装Apache 首先下载Apache源码压缩包,地址为http://mirror.bit.edu.cn/apache/httpd/ 继续下载apr和apr-util压缩包,地址为http ...
- 分享最新的博客到LinkedIn Timeline
使用Octopress作为我的博客框架有两年了.使用起来一直很顺手,这个工具真正的把博客跟写代码等同起来,非常酷炫.再加上各种各样的定制化,简直是随心所欲.我针对自己的需求对Octopress框架进行 ...
- Http Header里的Content-Type
之前一直分不清楚post请求里Content-Type方式,如application/x-www-form-urlencoded.multipart/form-data.本文会介绍Content-Ty ...
- 3.实现一个名为Person的类和它的子类Employee,Employee有两个子类Faculty 和Staff。
23.实现一个名为Person的类和它的子类Employee,Employee有两个子类Faculty 和Staff. 具体要求如下: (1)Person类中的属性有:姓名name(String类型) ...