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

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>
            国产中文一区二区| 国产日韩欧美在线看| 最新国产乱人伦偷精品免费网站| 麻豆国产精品777777在线 | 久久中文久久字幕| 久久久欧美精品sm网站| 亚洲福利视频三区| 亚洲精选在线观看| 一区二区三区成人| 国产视频一区二区在线观看| 狂野欧美激情性xxxx| 欧美18av| 午夜亚洲视频| 久久免费高清| 亚洲天堂偷拍| 久久久国产亚洲精品| 亚洲精品资源美女情侣酒店| 一区二区福利| 国内精品久久久久久久影视蜜臀 | 久久久另类综合| 欧美成人r级一区二区三区| 亚洲一区二区三区成人在线视频精品| 午夜视频在线观看一区二区三区| 亚洲国产另类久久久精品极度| 中日韩在线视频| 亚洲高清资源| 亚洲欧美激情视频| 99视频精品免费观看| 性久久久久久久久| 亚洲视频每日更新| 老司机亚洲精品| 欧美在线视频网站| 欧美日韩精品一区二区三区| 美女国产精品| 国产精品美腿一区在线看| 亚洲成人在线网站| 国产亚洲日本欧美韩国| 亚洲精品日韩精品| 最新高清无码专区| 久久成人免费网| 亚洲欧美日韩精品久久奇米色影视 | 亚洲一区二区网站| 99riav国产精品| 久久人人97超碰国产公开结果| 亚洲一区黄色| 欧美日韩p片| 亚洲电影网站| 亚洲欧洲一区二区三区久久| 久久久久久婷| 久久手机精品视频| 国产精品中文字幕欧美| 一区二区欧美日韩| 在线亚洲成人| 欧美日韩国产欧美日美国产精品| 欧美二区在线观看| 国内精品久久久久久久影视麻豆| 亚洲欧美日韩国产一区| 欧美专区在线观看| 国产九九视频一区二区三区| 亚洲免费网址| 欧美专区一区二区三区| 国产午夜精品在线| 久久精品人人做人人综合 | 亚洲破处大片| 欧美va亚洲va香蕉在线| 亚洲成人在线网| 最新日韩在线| 欧美另类69精品久久久久9999| 亚洲国产视频一区| 亚洲成人资源网| 欧美日韩精品一区二区| 亚洲美女尤物影院| 亚洲一区不卡| 国产日韩亚洲| 久久久久久久一区二区| 欧美成人日本| 一本久久综合亚洲鲁鲁| 欧美日韩在线直播| 这里只有视频精品| 久久精品国产一区二区三区| 国内精品久久久久影院色| 久久久天天操| 亚洲精品资源| 欧美在线观看一区二区三区| 国语自产精品视频在线看抢先版结局 | 午夜精品国产精品大乳美女| 国产欧美一级| 免费观看一区| 亚洲少妇最新在线视频| 久久九九热免费视频| 亚洲国产老妈| 国产精品视频大全| 裸体素人女欧美日韩| 一区二区三区蜜桃网| 久久久久久电影| 一本久久青青| 一区在线视频观看| 欧美日韩一区二区视频在线观看 | 欧美+亚洲+精品+三区| 亚洲图片欧洲图片日韩av| 久久久久久欧美| 一区二区免费在线视频| 国内精品福利| 欧美色大人视频| 麻豆av一区二区三区久久| 亚洲天堂av高清| 亚洲福利免费| 久久一区激情| 午夜精彩国产免费不卡不顿大片| 亚洲国产mv| 国产一区二区av| 欧美午夜a级限制福利片| 麻豆精品网站| 久久国产主播| 亚洲综合成人婷婷小说| 欧美大片一区二区| 久久久91精品| 欧美亚洲视频在线观看| 一区二区三区你懂的| 亚洲成色999久久网站| 国产亚洲精品bt天堂精选| 欧美日韩一区二区三区四区五区 | 蜜桃av综合| 久久精品五月| 欧美一级理论片| 亚洲综合日韩在线| 一区二区成人精品| 一区二区三区蜜桃网| 亚洲三级观看| 亚洲精品一区中文| 亚洲日本中文字幕| 亚洲国产精品久久91精品| 女人香蕉久久**毛片精品| 久久精品国产亚洲高清剧情介绍| 亚洲欧美电影在线观看| 亚洲无线一线二线三线区别av| 蜜桃久久av| 日韩亚洲国产精品| 亚洲人成在线免费观看| 亚洲国内自拍| 亚洲人成人99网站| 91久久精品一区二区三区| 欧美国产第一页| 欧美高清在线观看| 免费在线成人| 亚洲丁香婷深爱综合| 亚洲国产欧美一区| 最新日韩在线| 中文久久乱码一区二区| 亚洲视频一二| 性刺激综合网| 另类国产ts人妖高潮视频| 欧美大片一区二区三区| 欧美日韩另类国产亚洲欧美一级| 欧美久久久久| 国产精品免费小视频| 国产视频一区二区在线观看| 极品尤物av久久免费看| 亚洲国产精品综合| 亚洲一区二区av电影| 久久都是精品| 欧美好骚综合网| 正在播放亚洲| 欧美一区二区在线免费观看| 久久亚洲美女| 欧美三级午夜理伦三级中文幕| 国产精品免费看片| 一色屋精品亚洲香蕉网站| 亚洲精品男同| 欧美一区二区三区电影在线观看| 久久久久久久久久久成人| 亚洲第一狼人社区| 中文在线不卡视频| 久久久久久久波多野高潮日日| 欧美国产1区2区| 国产日韩精品久久久| 91久久午夜| 欧美伊人久久大香线蕉综合69| 久久综合久色欧美综合狠狠| 91久久线看在观草草青青| 亚洲欧美国产va在线影院| 美女国产一区| 国产精品看片你懂得| 亚洲国产精品久久| 欧美在线啊v一区| 91久久夜色精品国产九色| 久久国产精品高清| 欧美日在线观看| 亚洲激情成人网| 久久国产精品网站| 99精品热6080yy久久| 六月婷婷久久| 国产欧美精品在线| 一区二区久久| 亚洲国产婷婷香蕉久久久久久99 | 欧美日韩在线播放| 亚洲国产精品一区二区第一页| 亚洲欧美清纯在线制服| 亚洲欧洲精品一区二区精品久久久| 久久精品国产成人|