高斯消元原理

高消一直是ACM中高层次经常用到的算法,虽然线性代数已经学过,但高消求解的问题模型及高消模板的应用变化是高消的最复杂之处。

先介绍一下高消的基本原理:引入互联网czyuan的帖子:

高斯消元法,是线性代数中的一个算法,可用来求解线性方程组,并可以求出矩阵的秩,以及求出可逆方阵的逆矩阵。

高斯消元法的原理是:

若用初等行变换将增广矩阵 化为 ,则AX B与CX D是同解方程组。

所以我们可以用初等行变换把增广矩阵转换为行阶梯阵,然后回代求出方程的解。

 

以上是线性代数课的回顾,下面来说说高斯消元法在编程中的应用。

 

首先,先介绍程序中高斯消元法的步骤:

(我们设方程组中方程的个数为equ,变元的个数为var,注意:一般情况下是n个方程,n个变元,但是有些题目就故意让方程数与变元数不同)

 

1. 把方程组转换成增广矩阵。

 

2. 利用初等行变换来把增广矩阵转换成行阶梯阵。

枚举k从0到equ – 1,当前处理的列为col(初始为0) ,每次找第k行以下(包括第k行),col列中元素绝对值最大的列与第k行交换。如果col列中的元素全为0,那么则处理col 1列,k不变。

 

3. 转换为行阶梯阵,判断解的情况。

 

① 无解

当方程中出现(0, 0, …, 0, a)的形式,且a != 0时,说明是无解的。

 

② 唯一解

条件是k equ,即行阶梯阵形成了严格的上三角阵。利用回代逐一求出解集。

 

③ 无穷解。

条件是k equ,即不能形成严格的上三角形,自由变元的个数即为equ – k,但有些题目要求判断哪些变元是不缺定的。

    这里单独介绍下这种解法:

首先,自由变元有var k个,即不确定的变元至少有var k个。我们先把所有的变元视为不确定的。在每个方程中判断不确定变元的个数,如果大于1个,则该方程无法求解。如果只有1个变元,那么该变元即可求出,即为确定变元。

 

以上介绍的是求解整数线性方程组的求法,复杂度是O(n3)。浮点数线性方程组的求法类似,但是要在判断是否为0时,加入EPS,以消除精度问

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
高斯列主元法是一种用于解线性方程组的方法。它的基本原理是在高斯消去法的每一步中,选择一个绝对值最大的元素作为主元素。在进行行交换和消元操作之前,找到第k步时,从第k列及以下的各元素中选出绝对值最大的元素,并将其通过行变换交换到主元素的位置上。然后使用这个主元素来消去主对角线以下的其他元素,最终将线性方程组转化为上三角矩阵的形式。 通过使用列主元高斯消去法,可以有效地提高计算的精度。这种方法的基本思想是选择绝对值最大的元素作为主元素,从而减小计算误差的传播。这在实际应用中非常重要,特别是当矩阵A的某些元素非常接近或等于零时。 总结来说,高斯列主元法解线性方程组的原理是通过选择绝对值最大的元素作为主元素,并通过行交换和消元操作将线性方程组转化为上三角矩阵的形式,从而得到精确的解。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [高斯列主元法求线性方程组.rar](https://download.csdn.net/download/qq_35660456/12029516)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* *3* [数值计算——列主元高斯消去法求解线性方程组(附代码)](https://blog.csdn.net/weixin_41788456/article/details/103222038)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值