利用克拉莫法則求解n元線性方程組

来源:http://www.cnblogs.com/shuiming/archive/2016/03/14/5274400.html
-Advertisement-
Play Games

接上一篇隨筆,利用克拉莫法則求解n元線性方程組。 代碼:  


接上一篇隨筆,利用克拉莫法則求解n元線性方程組。

代碼:

  1 #include <iostream>
  2 #include <cmath>
  3 using namespace std;
  4 void appDescribe();                       //程式說明 
  5 double valDet( double* detPtr, int rank);  //求解行列式 
  6 class LinearEquations
  7 {
  8     public:
  9         LinearEquations();  //構造方程組
 10         void sol();         //求解
 11         void showAns();     //顯示解
 12     private:
 13         int rank;           //階數
 14         double* parPtr;     //繫數行列式
 15         double* conPtr;     //常數項
 16         double* ansPtr;     //
 17 };
 18 LinearEquations::LinearEquations()
 19 {
 20     cout<<"輸入方程元數:";
 21     cin>>rank;
 22     int rank2=rank*rank;
 23     parPtr=new double[rank2];
 24     conPtr=new double[rank];
 25     cout<<endl<<"輸入繫數行列式:"<<endl;
 26     for(int i=0;i<rank2;i++)
 27          cin>>parPtr[i];
 28     cout<<endl<<"輸入常數項:"<<endl;
 29     for(int i=0;i<rank;i++)
 30         cin>>conPtr[i];
 31 }
 32 void LinearEquations::sol()
 33 {
 34     int rank2=rank*rank;
 35     double det=valDet(parPtr,rank);
 36     ansPtr=new double[rank];
 37     double *tempParptr=new double[rank2];
 38     double tempDet;
 39     if(det==0)
 40     {
 41         ansPtr=NULL;
 42         return;
 43     }
 44     for(int i=0;i<rank;i++)
 45     {
 46         for(int j=0;j<rank2;j++)
 47             tempParptr[j]=parPtr[j];
 48         for(int j=0;j<rank;j++)
 49             tempParptr[i+j*rank]=conPtr[j];
 50         tempDet=valDet(tempParptr,rank);
 51         ansPtr[i]=tempDet/det;
 52     }
 53 }
 54 void LinearEquations::showAns()
 55 {
 56     if(ansPtr==NULL)
 57     {
 58         cout<<"該線性方程組無解或有無數解"<<endl;
 59         return;
 60     }
 61     cout<<endl<<"該線性方程組的解為:"<<endl;
 62     for(int i=0;i<rank;i++)
 63         cout<<'x'<<i+1<<':'<<ansPtr[i]<<endl; 
 64 }
 65 int main()
 66 {
 67     appDescribe();
 68     LinearEquations l1;
 69     l1.sol();
 70     l1.showAns();
 71     system("pause");
 72     return 0;
 73 }
 74 void appDescribe()
 75 {
 76     cout<<"***************************************"<<endl
 77         <<"本程式利用克拉莫法則求解n元線性方程組。"<<endl
 78         <<"案例:"<<endl
 79         <<"輸入方程元數:4"<<endl<<endl
 80         <<"輸入繫數行列式:"<<endl
 81         <<"1 1 1 1"<<endl
 82         <<"1 2 -1 4"<<endl
 83         <<"2 -3 -1 -5"<<endl
 84         <<"3 1 2 11"<<endl<<endl
 85         <<"輸入常數項:"<<endl
 86         <<"5 -2 -2 0"<<endl<<endl
 87         <<"該線性方程組的解為:"<<endl
 88         <<"x1:1"<<endl
 89         <<"x2:2"<<endl
 90         <<"x3:3"<<endl
 91         <<"x4:-1"<<endl
 92         <<"***************************************"<<endl;
 93 } 
 94 double valDet( double* detPtr, int rank)
 95 {
 96     double val=0;
 97     if(rank==1) return detPtr[0];
 98     for(int i=0;i<rank;i++)                 //計算餘子式保存在nextDetPtr[]中 
 99     {
100         double *nextDetPtr=new double[(rank-1)*(rank-1)];
101         for(int j=0;j<rank-1;j++)
102             for(int k=0;k<i;k++)
103                 nextDetPtr[j*(rank-1)+k]=detPtr[(j+1)*rank+k];
104         for(int j=0;j<rank-1;j++)
105             for(int k=i;k<rank-1;k++)
106                 nextDetPtr[j*(rank-1)+k]=detPtr[(j+1)*rank+k+1];
107         val+=detPtr[i]*valDet(nextDetPtr,rank-1)*pow(-1.0,i);
108     }
109     return val;
110 }
111 /*
112 數據1:
113 2
114 
115 1 2
116 2 1
117 
118 3 3 
119 數據2: 
120 4
121 
122 1 1 1 1
123 1 2 -1 4
124 2 -3 -1 -5
125 3 1 2 11
126 
127 5 -2 -2 0
128 */

 


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

-Advertisement-
Play Games
更多相關文章
  • WebApi2上進行依賴註入,在百度里能搜到的的完整解決方案的文章少之又少,缺胳膊斷腿。 和MVC5依賴註入的不同之處,並且需要註意的地方,標記在註釋當中。上Global代碼: 也沒有太多需要解釋的地方,Controller中還是構造器註入。開發中已經親測有效。    可以收藏,以後查看。  
  • 自從上次分享《Redis到底該如何利用?》已經有1年多了,這1年經歷了不少。從碼了我們網站的第一行開始到現在,我們的緩存模塊也不斷在升級,這之中確實略有心得,最近也有朋友探討緩存,覺得可以總結下分享下拙見,期待能有更深入的研究。 緩存是什麼? 我時常在群里或者在社區里看到有人對緩存有諸多疑問,搞不清
  •   在函數式編程中,可以把函數看作數據。函數也可以作為參數,函數還可以返回函數。比如,LINQ就是基於函數式編程的。 語句式編程可能這樣寫:   而使用函數式表達式,可以簡化為:   再來看一個過濾和排序的例子:   函數式編程可以寫成如下:   或   可見,在LINQ中,一個表達式(函數)的返回
  • 以下是 .NET Framework 4.5 中 ADO.NET 的新增功能。 以下是 .NET Framework 4.5 中用於 SQL Server 的 .NET Framework 數據提供程式的新增功能: ConnectRetryCount 和 ConnectRetryInterval 連
  • PHP,是英文超級文本預處理語言Hypertext Preprocessor的縮寫。PHP 是一種 HTML 內嵌式的語言,是一種在伺服器端執行的嵌入HTML文檔的腳本語言,語言的風格有類似於C語言,被廣泛的運用。自從1994年PHP語言的創建,神奇般的被追捧為網站設計的首選語言。2000年PHP4
  • 在C#中沒有獨立的函數存在,只有類的(動態或靜態)方法這一概念,它指的是類中用於執行計算或其它行為的成員。在Python中,你可以使用類似C#的方式定義類的動態或靜態成員方法,因為它與C#一樣支持完全的面向對象編程。你也可以用過程式編程的方式來編寫Python程式,這時Python中的函數與類可以沒
  • 鄭重聲明:本文是筆者網上翻譯原文,部分有做添加說明,所有權歸原文作者! 地址:http://www.cprogramming.com/c++11/rvalue-references-and-move-semantics-in-c++11.html C++一直致力於生成快速的程式。不幸的是,直到C++
  • 背景      在博客 噁心的0.5四捨五入問題 一文中看到一個關於 0.5 不能正確的四捨五入的問題。主要說的是 double 轉換到 BigDecimal 後,進行四捨五入得不到正確的結果: 輸出的結果為: 301353.0499999999883584678173065185546875301
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...