青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

Tauruser

Enjoy Every Day
posts - 34, comments - 95, trackbacks - 0, articles - 5
  C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

Gauss消去法直接求解方程組(附例程)

Posted on 2006-06-04 20:22 Tauruser 閱讀(3964) 評論(7)  編輯 收藏 引用 所屬分類: 數值計算

3.2 Gauss消去法

3.2.1 順序消去法

  Gauss消去法就是將方程組(3.1.1)通過(n-1)步消元,將(3.1.1)轉化為上三角方程組
       (3.2.1)
再回代求此方程組的解.
  下面記增廣矩陣,即
   
  第1步 設,計算l,記為,若用第一行加到第i行,可消去,用Gauss變換矩陣表示
    
令   
其中
  一般地,假定已完成了(k-1)步消元,即已將轉化為以下形式:
   
  第k步,假定,計算
       (3.2.2)
,,則
   
其中
     (3.2.3).
當k=1,2,…,n-1則可得到,即方程組(3.2.1).

  直接回代解(3.2.1)得,
     (3.2.4)
并且有,由以上順序消去過程可得如下定理.
  定理2.1 設非奇異,則通過兩行互換總可使,k=1,2,…,n-1.可將方程組(3.1.1)轉化為(3.2.1)并求得方程組(3.1.1)的解為(3.2.4),且有.
  如果不做行交換,則使的條件如下.

  定理2.2 非奇異,且各階順序主子式, 則,k=1,2,…,n-1.
  證明 用歸納法,當,故.現假設(k-1)成立,即,對i=1,2,…,k-1已推出,故Gauss消去法能進行(k-1)步消元,A已約化為,即
   

     

對k=1,2,…,n均成立,證畢.
  在整個消去法消元過程中,k從1到(n-1)共需乘除法運算次數為
     
加減法次數為
     
回代過程中由公式(3.2.4)可知乘除法次數為,加減法次數為,于是Gauss消去法的乘除法總次數為,加減法次數為
  例3.4 用Gauss消去法解方程組
      
并求detA.
  解 消元得
   
再由(3.2.4)回代,得解

講解:

  Gauss 消去法是將方程組AX=b,通過消元轉化為上三角方程組(3,2,1)求解,消元第一步做完后有
         
  用矩陣表示
  第K-1步完成后得到
  當,可做K步,得到
  得到,對應的方程組就是(3.2.1),利用公式(3.2.4)就可求得解。
  定理2.2給出了進行順序消去法的條件,即A的所有順序生子式,而方程(3.1.1)解存在唯一的條件是

好了,原理講完了,貼我的例程。

#include? < iostream >
#include?
< vector >
#include?
< cmath >
using ? namespace ?std;
class ?CGAUSSSOLVEEQU
{
private :
????vector
< vector < double >> ?m_equset;
????vector
< double > ?m_answer;
????unsigned?
int ?m_n;
public :
????
void ?inputEquSet();
????
void ?solveEquSet();
????
void ?outputAnswer();
}
;
void ?CGAUSSSOLVEEQU::inputEquSet()
{
????
double ?dtemp;
????vector
< double > ?vtemp;
????cout
<< " 請輸入你的方程個數: " ;
????cin
>> m_n;
????cout
<< " 請按照向量的形式輸入各變量的系數。最后一位為b。每個方程一行: " << endl;
????
for (unsigned? int ?i( 0 );i < m_n; ++ i)
????
{
????????m_equset.push_back(vtemp);
????????
for (unsigned? int ?j( 0 );j <= m_n; ++ j)
????????
{????
????????????cin
>> dtemp;
????????????m_equset[i].push_back(dtemp);
????????}

????????
if (m_equset[i].size() != m_n + 1 )
????????
{
????????????cout
<< " 輸入有誤,請重新輸入上一個方程。 " << endl;
????????????
-- i;
????????}

????}

????
}


void ?CGAUSSSOLVEEQU::solveEquSet()
{
????vector
< vector < double >> ::iterator?iter;
????iter
= m_equset.begin();
????
for (unsigned? int ?m( 0 );m < m_n - 1 ; ++ m)
????
{
????????
// 將絕對值最大的主元素移上去。此舉是為了減少誤差
???????? for (vector < vector < double >> ::iterator?iter2 = iter + 1 ;iter2 != m_equset.end(); ++ iter2)
????????
{
????????????
if (fabsl(iter -> front()) < fabsl(iter2 -> front()))
????????????
{
????????????????swap(
* iter, * iter2);
????????????}

????????}

????????
// 進行消元
???????? for (unsigned? int ?i = m + 1 ;i < m_n; ++ i)
????????
{
????????????
double ?dm;
????????????dm
= m_equset[i][m] / m_equset[m][m];
????????????
for (unsigned? int ?j = m;j < m_n + 1 ; ++ j)
????????????
{
????????????????m_equset[i][j]
-= dm * m_equset[m][j];
????????????}

????????}

????????
++ iter;
????}

????
// 初始化m_answer向量
???? for (unsigned? int ?i( 0 );i < m_n; ++ i)?m_answer.push_back( 0 );
????
// 求解答案
????m_answer[m_n - 1 ] = m_equset[m_n - 1 ][m_n] / m_equset[m_n - 1 ][m_n - 1 ];

????
for ( int ?i = m_n - 2 ;i >= 0 ; -- i)
????
{
????????m_answer[i]
= m_equset[i][m_n];
????????
for ( int ?j = m_n - 1 ;j > i; -- j)
????????????m_answer[i]
-= m_answer[j] * m_equset[i][j];
????????m_answer[i]
/= m_equset[i][i];
????}


????
}


void ?CGAUSSSOLVEEQU::outputAnswer()
{
????
for (unsigned? int ?i( 1 );i <= m_n; ++ i)
????
{
????????cout
<< " x( " << i << " )= " << m_answer[i - 1 ] << endl;
????}

}


int ?main()
{
????CGAUSSSOLVEEQU?myEqu;
????myEqu.inputEquSet();
????myEqu.solveEquSet();
????myEqu.outputAnswer();
????
return ? 0 ;
}


// Power?By?Tauruser?2006.6.4

Feedback

# re: Gauss消去法直接求解方程組(附例程)  回復  更多評論   

2006-11-17 13:38 by tim
ding

# re: Gauss消去法直接求解方程組(附例程)  回復  更多評論   

2007-06-01 11:12 by Snowfox
請問LZ:
能發下具體的結果嗎?我不明白你的輸入格式,還有能解幾元幾次的方程組。謝謝了!勞駕!
期待中。。。

# re: Gauss消去法直接求解方程組(附例程)  回復  更多評論   

2007-06-10 12:02 by 星夢情緣
我的BLOG集齊了各重解線性方程的方法,任意方程都可以解的

# re: Gauss消去法直接求解方程組(附例程)  回復  更多評論   

2008-06-04 20:11 by
有一個小錯誤

# re: Gauss消去法直接求解方程組(附例程)  回復  更多評論   

2008-06-04 20:11 by
for ( int i = m_n - 2 ;i >= 0 ; -- i)

i 重復定義了,不過謝謝你呀!

# re: Gauss消去法直接求解方程組(附例程)  回復  更多評論   

2008-06-04 20:12 by
好程序

# re: Gauss消去法直接求解方程組(附例程)  回復  更多評論   

2009-03-25 22:06 by nan
能把改后的程序發上去嗎,謝謝
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            亚洲在线观看视频网站| 久久精品电影| 久久免费视频这里只有精品| 亚洲视频在线免费观看| 亚洲欧洲一二三| 亚洲国产精品福利| 一本久道久久综合婷婷鲸鱼| 一本高清dvd不卡在线观看| 亚洲美女精品成人在线视频| 亚洲精品之草原avav久久| 日韩西西人体444www| 99re热精品| 亚洲中字在线| 久久亚洲一区二区三区四区| 欧美成人高清视频| 欧美日韩一级大片网址| 国产欧美一区视频| 在线观看日韩欧美| 一区二区三区国产精品| 欧美亚洲免费电影| 欧美va亚洲va香蕉在线| 亚洲免费观看| 午夜欧美大尺度福利影院在线看| 欧美一区激情| 欧美久久久久中文字幕| 国产精品私房写真福利视频| 亚洲国产乱码最新视频| 亚洲欧美另类久久久精品2019| 久久久精品一区| 亚洲精品中文字幕在线观看| 欧美一区二区三区免费看| 欧美精品成人| 狠狠综合久久av一区二区小说| 一二三区精品| 免费在线看一区| 亚洲欧美国产日韩天堂区| 欧美成人影音| 亚洲电影免费在线观看| 亚洲综合精品四区| 欧美国产日韩一区二区在线观看| 亚洲欧美久久久| 欧美乱妇高清无乱码| 精品88久久久久88久久久| 亚洲自拍16p| 亚洲精品国久久99热| 亚洲午夜激情免费视频| 欧美高清视频免费观看| 亚洲在线视频观看| 欧美精品成人在线| 亚洲第一福利在线观看| 午夜精品在线| 亚洲乱码国产乱码精品精可以看| 久久夜色精品国产欧美乱| 国产一区二区精品久久99| 亚洲免费在线观看| 一本不卡影院| 欧美视频在线免费看| 亚洲精品日韩一| 亚洲福利视频网站| 裸体一区二区| 亚洲欧洲另类| 亚洲精品视频在线看| 免费亚洲电影在线| 最新亚洲激情| 欧美日韩中文字幕综合视频| 美女国产一区| 亚洲大黄网站| 亚洲国产成人不卡| 欧美成人视屏| 一本久道综合久久精品| 欧美国产日韩一区二区三区| 久色婷婷小香蕉久久| 亚洲精品1区2区| 亚洲福利电影| 欧美特黄视频| 久久国产精品网站| 久久精品亚洲一区二区三区浴池| 国产在线高清精品| 久久一区二区三区av| 老色鬼久久亚洲一区二区| 亚洲日本理论电影| 99视频精品免费观看| 国产精品一级二级三级| 欧美在线观看视频一区二区三区 | 蜜桃久久av| 久久婷婷一区| 99视频在线精品国自产拍免费观看| 91久久精品国产91久久性色tv| 欧美电影在线播放| 亚洲综合不卡| 欧美在线综合视频| 亚洲精品女人| 亚洲欧美成人网| 亚洲国产精品女人久久久| 亚洲精品视频在线看| 国产欧美韩日| 欧美高清日韩| 国产精品影片在线观看| 欧美不卡视频一区发布| 欧美午夜无遮挡| 免费在线亚洲| 国产精品v欧美精品∨日韩| 另类图片综合电影| 欧美日韩久久不卡| 老司机亚洲精品| 欧美日韩综合| 蜜桃av一区二区三区| 国产精品乱子久久久久| 美国十次成人| 国产精品色婷婷久久58| 亚洲国产一区二区a毛片| 国产深夜精品| 99精品99| 亚洲欧洲另类国产综合| 欧美亚洲网站| 亚洲午夜精品视频| 老司机67194精品线观看| 久久精品国产亚洲一区二区三区 | 亚洲免费网址| 欧美不卡视频一区| 久久久精品国产免费观看同学| 欧美视频中文字幕在线| 欧美国产一区二区在线观看| 国产一区二区三区视频在线观看| 欧美不卡一卡二卡免费版| 久久国产精品久久久久久| 欧美电影在线| 亚洲电影欧美电影有声小说| 国产综合在线看| 亚洲你懂的在线视频| 亚洲一区久久久| 欧美日韩a区| 在线视频欧美日韩精品| 欧美国产在线电影| 欧美国产第二页| 亚洲电影av在线| 久久尤物视频| 欧美成人午夜剧场免费观看| 黑丝一区二区| 欧美一区在线直播| 久久深夜福利| …久久精品99久久香蕉国产| 欧美成人免费大片| 亚洲国内精品在线| 裸体歌舞表演一区二区| 亚洲国产精品热久久| 日韩网站免费观看| 亚洲综合首页| 久久久久国产一区二区三区四区| 国产日韩精品视频一区| 欧美在线高清视频| 美女国产一区| 亚洲三级视频| 欧美亚洲第一页| 亚洲欧美日韩专区| 乱人伦精品视频在线观看| 亚洲高清激情| 欧美日韩一卡二卡| 午夜精品剧场| 欧美成人午夜| 亚洲欧美国内爽妇网| 国产老肥熟一区二区三区| 久久精品一区四区| 欧美高清视频一区| 中文国产一区| 黄色亚洲网站| 欧美成人激情视频免费观看| 日韩视频永久免费观看| 欧美一区二区三区视频| 久久综合影视| 亚洲一区二区精品在线| 久久蜜臀精品av| 一区二区三区你懂的| 国产精品视频专区| 美国十次了思思久久精品导航| 一本色道久久综合亚洲91| 久久精品99久久香蕉国产色戒| 亚洲成人资源| 国产日韩欧美成人| 另类激情亚洲| 免费观看30秒视频久久| 一区电影在线观看| 国产综合网站| 国产精品美女黄网| 欧美高清hd18日本| 欧美在线观看视频| 在线综合视频| 亚洲国产成人久久| 久久九九精品99国产精品| 亚洲视频一区二区免费在线观看| 国内精品久久久久影院优 | 国产欧美在线观看| 欧美韩日视频| 久久久久久久久久看片| 午夜精品美女久久久久av福利| 欧美黄色精品| 久久精品夜色噜噜亚洲aⅴ| 亚洲性感激情| 亚洲精品一区在线观看香蕉| 嫩模写真一区二区三区三州|