date
slug
status
tags
type
类型
summary
在这里感谢我的学长以及

前言

前几天刚开始学线性代数,于是就想用C++复现一下
本来以为是很简单的,但是后期纠错花了好几个晚上才搞定
毕竟我太菜了
C++源码已上传至GitHub

项目地址

源码

解析

n阶行列式定义

notion image
这里将行列式中的每项视为一个二维数组
notion image
其中在开头定义的常量
为本程序所能运算的最大阶数

n阶行列式的定义式

notion image
可以看出:
n阶行列式在运算时由两个部分组成
  • 第一部分是系数,在所选的序列的总逆序数为偶数时取1,奇数为-1
  • 第二部分是所选序列的累乘那么在编写程序时也可分成这两项来分别编写n阶行列式的构成其中,系数k由函数t(int p[N],int n)生成累乘部分由函数product(double x[max_n][max_n],int p[N],int n)生成
    • notion image

系数的生成

由于定义中规定不能选中同行同列的项相乘,但由于这个实现起来比较麻烦,所以就将同列的情况所对应系数为0
即:
  • 序列为偶逆序,函数返回1
  • 序列为奇逆序,函数返回-1
  • 序列为同列,函数返回0

累乘的生成

这个没什么好说的,将结果的值先初始化为1,然后从序列p[]中读取每轮所要取第几行第几列的值,然后用for循环实现累乘即可

序列的生成

这个想了很久,后来请教了我计科的学长,用n位n进制来实现:
这是一个n*n的矩阵,每行取一个数,需要遍历每一种结果,因此共有n^n种不同的取法
那么可以由这么一个数表示每行所要取第几列,也就是一个n位长的数,每一轮个位都自增1,逢n进1,直到n^n种情况遍历完为止
这个数的每一位都表示该行取第几列,比如个位数表示第一行取第几位,十位数表示第二位取第几位,n位数表示第n行取第几位
每次先自增1,再由一个for循环嵌套if来判断是否需要进位
为方便,就将这段序列数存储在了数组p[]
并且在此之前需要将数组初始化
这段代码被写在了sum(double x[max_n][max_n],int n)

所遇到的问题

1. 数组索引溢出

定义数组时用的x[max_n][max_n],但是在for循环中所遍历的范围是1-max_n,超出了数组所定义的范围
所以后期调整为遍历0-max_n

2. 乘方的表示

之前写乘方时使用的是n^n,但在C++中^表示异或
正确的方式是在头文件中调用<cmath>,然后使用pow()函数
pow()函数的使用方法:
pow(x,y)表示x的y次方

3. C++环境出错

后来发现所有的错误都排除了,但是还是不能正常输出D的值,但是在学长的电脑上能正常运行的,因此发现是环境问题
将VSCode换为Dev C++后居然就能正常运行了
目前该问题笔者还在研究中

小结

肝这个代码花了我近四天晚上的时间来构思和修改错误
尽管并非作业,但是能用自己所学的C++来实现某项功能还是很有成就感的
也很感谢有大佬在我遇到困难时能出手相助
相关文章
解线性方程组的直接解法
Lazy loaded image
一道小学数学题引发的思考
Lazy loaded image
微分方程初值问题及matlab代码
Lazy loaded image
数学建模-优劣解距离法(TOPSIS)
Lazy loaded image
数学建模-层次分析法(AHP)
Lazy loaded image
使用C++实现克拉默法则(Cramer's law)
Lazy loaded image
TpCache引发的Typecho评论delete()报错及解决方法iOS设备利用快捷指令半自动登录Drcom校园网
Loading...
Steven Lynn
Steven Lynn
喂马、劈柴、周游世界
最新发布
我与 Dify 的半年
2025-3-9
我的2022年终小结
2024-11-9
记录雅思考试经历与一点学习心得
2024-11-9
Hackergame 2024 思路小结
2024-11-9
黑客松、日本、入职:我的2024下半年的总结
2024-11-9
NotionNext:基于Notion和NextJS的开源博客
2024-11-9