`
eimhee
  • 浏览: 2162257 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

多元一次方程组的求解

阅读更多

求解多元一次方程组:

f(1,1)x1+f(1,2)x2+f(1,3)x3+...=f(1,n)

f(2,1)x1+f(2,2)x2+f(2,3)x3+...=f(2,n)

f(3,1)x1+f(3,2)x2+f(3,3)x3+...=f(3,n)

......

f(m,1)x1+f(m,2)x2+f(m,3)x3+...=f(m,n)

采用高斯消元法:

Option Base 1
  Function Determinant(ByRef factor) As Single
            Dim i     As Long, j       As Long, k       As Long, row       As Long, order       As Long
            Dim r     As Long, c       As Long, Pivot       As Single, Pivot2       As Single, temp()       As Single
            Determinant = 1
            Dim m
             
            m = factor
            row = UBound(m, 1)
            If Not UBound(m, 2) = row + 1 Then MsgBox "无解或不定解!":                       Exit Function
            ReDim temp(1 To row)
             
            For i = 1 To row
             
                      Pivot = 0
                      For j = i To row
                                For k = i To row
                                          If Abs(m(k, j)) > Pivot Then
                                                    Pivot = Abs(m(k, j))
                                                    r = k:       c = j
                                          End If
                                Next k
                      Next j
                       
                      If Pivot = 0 Then Determinant = 0:                 Exit Function
                       
                      If r <> i Then
                                order = order + 1
                                For j = 1 To row
                                          temp(j) = m(i, j)
                                          m(i, j) = m(r, j)
                                          m(r, j) = temp(j)
                                Next j
                      End If
                       
                      If c <> i Then
                                order = order + 1
                                For j = 1 To row
                                          temp(j) = m(j, i)
                                          m(j, i) = m(j, c)
                                          m(j, c) = temp(j)
                                Next j
                      End If
                       
                      Pivot = m(i, i)
                      Determinant = Determinant * Pivot
                       
                      For j = i + 1 To row
                                Pivot2 = m(j, i)
                                If Pivot2 <> 0 Then
                                          For k = 1 To row
                                                    m(j, k) = m(j, k) - m(i, k) * Pivot2 / Pivot
                                          Next
                                End If
                      Next
                       
            Next
             
            Determinant = Determinant * (-1) ^ order
  End Function
   
  Sub getresult(ByRef factor(), ByRef answer As String)
  Dim row     As Integer, i       As Integer, D0       As Single
  Dim m
  Dim result()     As String
  row = UBound(factor, 1)
  ReDim result(1 To row)
  D0 = Determinant(factor)
  If D0 = 0 Then MsgBox "无解!":               Exit Sub
  For i = 1 To row
    m = factor
  For j = 1 To row
  m(j, i) = factor(j, row + 1)
  Next
  result(i) = "X" & i & "=   " & Format(Determinant(m) / D0, "0.00")                         '   Di/D0
  Next
  answer = Join(result, vbCrLf)
  End Sub
   
  Private Sub Command1_Click()
  Dim Param(3, 4)       '   三元一次方程组
  Dim i     As Integer
  For i = 1 To 4
  Param(1, i) = Choose(i, 1, 1, 1, 6)                   '   x1+x2+x3=6
  Param(2, i) = Choose(i, 2, -1, 3, 5)                 '   2x1-x2+3x3=5
  Param(3, i) = Choose(i, 4, 2, -3, 3)                   '4x1+2x2-3x3=3
  Next
  Dim answer     As String
  getresult Param, answer
  Debug.Print answer

  End Sub

 返回:

X1=   0.83
X2=   3.04
X3=   2.13

分享到:
评论

相关推荐

    多元一次方程组计算器——环星多元线性方程组计算器0.89β

    总结来说,环星多元线性方程组计算器0.89β是一款基于线性代数理论的实用软件,它涵盖了多元一次方程组的各种求解方法,并通过友好的用户界面降低了计算的复杂性,提高了效率。无论你是学生还是专业工程师,这款工具...

    多元一次方程组的三种算法

    多元一次方程组是数学中的基础概念,尤其在解决实际问题时经常遇到。它涉及到多个变量和多个等式,每个等式对应一个变量之间的关系。本主题主要关注三种解决多元一次方程组的方法:克拉默规则(Cramer's Rule)、...

    多元一次方程组解方程源代码

    多元一次方程组是数学中的一个基础概念,它由多个未知数和多个方程式组成,每个方程式都涉及这些未知数。在实际问题中,如物理、工程、经济等领域,常遇到这类问题,需要找到一组合适的数值解来满足所有方程。解决这...

    C++解多元一次方程组的代码

    本主题聚焦于使用C++解决多元一次方程组的问题,这是一个常见的数学问题,在工程、物理和计算机科学等多个学科都有广泛应用。多元一次方程组通常涉及到多个变量和多个方程式,其解决方案可能包含一个或多个变量的值...

    java解多元一次方程组

    很简单的程序,可以接多元一次方程组,在数值计算和线性代数中应用。

    求多元解线性方程组,线性方程组全部解,matlab

    线性方程组是由若干个含有相同未知数的一次方程组成的集合。对于一个四元非齐次线性方程组,我们可以表示为: \[ ax_1 + bx_2 + cx_3 + dx_4 = e \] \[ fx_1 + gx_2 + hx_3 + ix_4 = j \] \[ kx_1 + lx_2 + mx_3 + ...

    多元非线性方程组求解 牛顿--拉夫逊方法含matlab案例代码.docx

    牛顿-拉夫逊方法是解决多元非线性方程组的一种强大迭代技术,它基于一阶泰勒展开,通过迭代逼近方程组的根。该方法的核心思想是利用方程组的局部线性化来近似原问题,然后通过求解线性系统的解来更新迭代点。 在...

    JAVA实现多元一次方程组的算法.docx

    本文档介绍了一种使用Java编程语言实现的多元一次方程组求解算法——高斯消元法。高斯消元法是一种广泛应用于线性代数领域的有效方法,用于解决线性方程组问题。该方法首先通过一系列行变换将系数矩阵转换为一个上...

    多元一次方程线性拟合

    多元一次方程线性拟合是统计学和数据分析中的一个重要概念,主要应用于寻找变量间的关系。在本项目中,使用C++编程语言在VS2010环境下实现了这一功能,利用了最小二乘法来确定最佳拟合直线。最小二乘法是一种优化...

    多元方程组求解

    多元方程组求解,自己写的

    多元一次方程组解答工具

    用于求解多元一次方程组,按照EXCEL提示输入各项系数即可求解

    excel求解多元一次方程

    除了克莱姆法则外,Excel还提供了一个强大的插件——“规划求解”,用于解决各种优化问题,包括求解多元一次方程组。 **步骤说明**: - **安装规划求解插件**:首先确保已经安装了“规划求解”插件。如果未安装,...

    多元二次非线性方程组求解

    通过牛顿方法解决多元二次非线性方程(根据数学分析书内容),将程序分为函数值求解,雅各比矩阵求解,线性方程组牛顿求解和主程序三部分,线性方程组求解采用高斯列消元方法。如果有需要,函数和雅各比矩阵需要按需...

    解多元一次方程

    多元一次方程是数学中的一个...总的来说,理解和掌握多元一次方程的求解方法,尤其是高斯消元法和列主元素消元法,是数学、工程、科学等领域的重要基础。而利用专门的计算工具,则能帮助我们快速准确地解决实际问题。

    牛顿迭代法求解多元非线性方程组(附matlab仿真代码)

    #### 多元非线性方程组求解 对于多元非线性方程组的求解,牛顿迭代法的基本步骤相似,但需要考虑偏导数矩阵(雅克比矩阵)的构造与求逆。 1. **初始化**: 给定初始估计值 \( \mathbf{x}_0 \) 和迭代终止条件 \(\...

    python求解多元多次方程组或非线性方程组

    背景:如何使用python求解多元多次方程组或者非线性方程组。 原创内容,转载注明出处!请勿用于商业用途! (上篇用python拟合2019nCov感染人数的文章被不少博主转载了,发的比较早,不少博主在文章基础上添加新内容...

    用MATLAB求解微分方程及微分方程组

    用MATLAB求解微分方程及微分方程组方法介绍和例子。Matlab

    JS 多项式运算及线性方程组求解

    本实验主要涉及的是多项式运算和线性方程组的求解,这些都是数学在计算机科学中的重要应用。下面我们将详细探讨这些知识点。 首先,**多项式运算**在计算机科学中广泛用于图形学、数值计算和信号处理等领域。在...

    利用Excl求解多元一次方程.rar

    Excel不仅是一个电子表格工具,还提供了强大的数学和统计功能,包括矩阵运算,这使得它能够解决线性代数中的问题,如多元一次方程组。下面我们将详细探讨如何利用Excel来求解这类问题。 首先,我们要理解什么是多元...

    二元二阶微分方程组求解,并画出极坐标图(matlab)

    在MATLAB中,二元二阶微分方程组的求解是一项常见的任务,尤其在物理学、工程学和数学等领域。二阶微分方程通常用于描述物体的动态行为,如振动系统的运动、电磁场的变化等。对于二元二阶微分方程组,它涉及两个变量...

Global site tag (gtag.js) - Google Analytics