C#程式計算N階行列式的值及N元一次方程組

来源:https://www.cnblogs.com/fangexuxiehuihuang/archive/2019/10/09/11644103.html
-Advertisement-
Play Games

C#程式計算N階行列式的值及N元一次方程組 用了挺長時間自行完成了C#程式計算N階行列式的值及N元一次方程組。由於自己沒有在網上查閱其他資料,所以只能硬著頭皮用最朴素的思想和基礎的演算法進行編程。在給出代碼之前,我先簡單發表一些自己的粗鄙之見。。。 1.數學思想:有了線性代數中高斯提供的公式,我們很容 ...


C#程式計算N階行列式的值及N元一次方程組

  用了挺長時間自行完成了C#程式計算N階行列式的值及N元一次方程組。由於自己沒有在網上查閱其他資料,所以只能硬著頭皮用最朴素的思想和基礎的演算法進行編程。在給出代碼之前,我先簡單發表一些自己的粗鄙之見。。。

  1.數學思想:有了線性代數中高斯提供的公式,我們很容易就能得到N階方程的解的統一計算方法:即xn=Dn/D。其中D是繫數矩陣的行列式值,Dn是用每個方程的結果分別代替繫數矩陣中的每列值,所得新的行列式的值。 那麼我們的關鍵問題就是(1)如何計算一個N階行列式的值(2)如何得到N個新的行列式。下麵就對這兩個關鍵問題進行探討。

  2.問題一:如何計算N階行列式的值。我沒有選用網上的一些諸如“加邊法”等一些方法。選用了N階行列式最基本的計算公式。即求任意一行或列的所有元素乘以他們的餘子式,進行降階,最後在二階用主對角線之積減副對角線之積進行計算。朴素的思想有著“易理解,難操作或性能低”的特點。選用這種方法的本質就是:遞歸。

  3.問題二:問題二相對問題一而言更好解決,對每列進行遍歷,用方程值組代替列組,創建新的行列式放到問題一的函數中計算即可。

  下麵附上代碼:

static void Main()
        {
            bool tap = true;
            while (tap)
            {
                //輸出標題並輸入階數
                Console.SetCursorPosition(48, 3); Console.WriteLine("解N元一次方程組");
                Console.Write("請輸入N元方程組的階數(未知數的個數):");
                int n = Convert.ToInt32(Console.ReadLine());

                //依次輸入每行方程的繫數和結果
                double[,] Xishu = new double[n, n];
                double[] zhi = new double[n];
                double[] EachLineResult = new double[n];
                Console.WriteLine("請依次輸入每行的繫數數和結果數:");
                Console.WriteLine();
                for (int i = 0; i < n; i++)
                {
                    Console.WriteLine("請輸入第{0}行的繫數值和結果值", i + 1);
                    for (int j = 0; j < n; j++)
                    {
                        Xishu[i, j] = Convert.ToDouble(Console.ReadLine());
                    }
                    Console.WriteLine("請輸入第{0}行的結果值", i + 1);
                    zhi[i] = Convert.ToDouble(Console.ReadLine());
                }

                //計算行列式的值和用結果值代替繫數的行列式的值
                double result = Hanglieshi(n, Xishu);
                //測試用句1: Console.WriteLine("計算出行列式的結果為:{0}", result);
                if (result == 0) Console.WriteLine("此方程無解!");//行列式值為0,方程無解
                else
                {
                    for (int i = 0; i < n; i++)
                    {
                        double[,] TempXishu = new double[n, n];
                        for (int ii = 0; ii < n; ii++)
                        {
                            for (int jj = 0; jj < n; jj++)
                            {
                                TempXishu[ii, jj] = Xishu[ii, jj];
                            }
                        }
                        EachLineResult[i] = Rexishu(i, TempXishu, zhi, n);
                        //測試用句2: Console.WriteLine("第{0}個結果行列式的值為:{1}",i+1,EachLineResult[i]);
                    }

                    //輸出每一個結果的值
                    Console.WriteLine();
                    Console.WriteLine("{0}元一次方程組的解集如下:", n);
                    for (int i = 0; i < n; i++)
                    {
                        Console.WriteLine("X{0}:{1}", i + 1, EachLineResult[i] / result);
                    }
                }
                
                Console.WriteLine();
                Console.WriteLine("你是否要繼續計算?回答:是或不是");
                string choice = Console.ReadLine();
                while (choice != ""&& choice  != "不是") choice = Console.ReadLine();
                if (choice == "") {  Console.Clear();  }
                else tap = false;
            }
            
            //計算行列式函數:利用遞歸和行列式的數學計算式計算。時間複雜度為O(n三次方),性能較低。
            double Hanglieshi (int N,double [,] xishu)
            {
                double Mo = 0;
                if (N == 0) return 0;
                else if (N == 1) return xishu[0, 0];
                else if (N == 2) return xishu[0, 0] * xishu[1, 1] - xishu[0,1] * xishu[1,0];
                else
                {
                    
                    for (int i = 0; i < N; i++)
                    {    
                        double[,] NewXishu = new double[N - 1, N - 1];
                        for(int j = 0; j < N - 1; j++)
                        {
                            int mark = 0;
                            for (int k = 0; k <N-1; k++)
                            {
                                
                                if (k == i) { NewXishu[j, k] = xishu[j + 1, mark + 1]; mark++; }
                                else NewXishu[j, k] = xishu[j + 1, mark];
                                //Console.WriteLine("k的值為:{0}\tmark的值為:{1}\t數組的值為:{2}",k,mark,NewXishu[j,k]);
                                mark++;
                            }
                        }
                        //Console.WriteLine("這是第{0}次迴圈",i+1);
                        if(i%2==0)
                            Mo += xishu[0,i]*Hanglieshi(N - 1, NewXishu);
                        else
                            Mo -= xishu[0, i] * Hanglieshi(N - 1, NewXishu);
                    }
                    return Mo;
                }
            }
            /*創建新的數組讓方程結果值代替列值,時間複雜度為O(n)主要問題在空間複雜度上,傳
            參時,需要把原數組複製,所以要O(n三次方)。註意:正常函數傳參是按值傳參,函數內形參不
            改變函數外部實參的值。但是數組比較特殊,會被更改。 */
            double Rexishu(int lieshu,double [,]xishu,double[]Zhi,int Size)
            {
                Console.WriteLine();

                for (int i = 0; i <Size; i++)
                {
                    xishu[i, lieshu] = Zhi[i];
                }
                double resulti=Hanglieshi(Size,xishu);
                return resulti;
            }

        }

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 本文主要講解Spring的基礎環境搭建以及演變由來,僅供學習分享使用,如有不足之處,還請指正。 ...
  • 實驗環境:WIN7虛擬機 軟體:VC6 首先在VC6裡面寫一個空函數Fun(); F7編譯運行一下,沒有出錯,接著在函數處使用F9下斷點,使程式運行到Fun函數時停下。 接著F5開始運行這個程式 程式停在了Fun函數處,反彙編進去進行逆向分析 可以看到程式停在Fun函數的入口處,這裡的call就是F ...
  • 摘要 在 "詳解http報文" 一文中,詳細介紹了http報文的文本結構。那麼作為服務端,web容器是如何解析http報文的呢?本文以jetty和undertow容器為例,來解析web容器是如何處理http報文的。 在前文中我們從概覽中可以瞭解到,http報文其實就是一定規則的字元串,那麼解析它們, ...
  • composer是什麼 composer是PHP的插件依賴管理工具,我個人感覺和java的Maven、Gradle很類似。 Windows OS下安裝composer 參考: https://www.php.cn/php weizijiaocheng 400785.html https://blog ...
  • 聊起中斷,大家可能最熟悉的例子就是線程休眠。下麵就是一個線程休眠的 demo,在這個例子中,當我們調用 方法,該方法將會拋出一個需要捕獲的中斷異常,這裡捕獲該異常並直接返回。 java for (int i = 0; i An interrupt is an indication to a thre ...
  • 使用Mybatis查詢客戶端信息 前面的例子使用了預設的jdbc配置來動態從資料庫查詢客戶端信息,下麵來改用更加靈活的mybatis來實現,改用mybatis,首先pom中換成mybatis的依賴: 然後新建一個實體類,並實現查詢需要的 ClientDetails 介面: 由於介面預設需要實現的方法 ...
  • 類型和變數 [C#類型和變數(原文參考官方教程)]https://docs.microsoft.com/zh-cn/dotnet/csharp/tour-of-csharp/types-and-variables C#有兩種類型: 1. 值類型 1. 簡單類型 2. 枚舉類型 格式為 enum E ...
  • 委托 1. C# 中的委托類似於 C 或 C++ 中指向函數的指針。委托表示引用某個方法的引用類型變數,運行時可以更改引用對象。 2. 特別地,委托可以用於處理事件或回調函數。並且,所有的委托類都是從 System.Delegate 類繼承而來。 聲明委托的語法規則:(被委托所引用的方法需有相同的參 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...