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

Tauruser

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

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

Posted on 2006-06-04 20:22 Tauruser 閱讀(3984) 評論(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
能把改后的程序發上去嗎,謝謝

只有注冊用戶登錄后才能發表評論。
網站導航: 博客園   IT新聞   BlogJava   博問   Chat2DB   管理


青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <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>
            中文在线一区| 欧美伊人影院| 欧美日韩高清在线| 一本久久精品一区二区| 亚洲精品乱码久久久久久按摩观| 久久综合五月| 一本综合久久| 亚洲一区二区三区在线看| 国产精品自拍视频| 久久久综合激的五月天| 久久亚洲一区二区三区四区| 亚洲国产天堂久久国产91| 亚洲激情社区| 国产精品久久久久久久浪潮网站 | 国产欧美日韩不卡| 久久成人久久爱| 久久五月婷婷丁香社区| 亚洲精品四区| 亚洲线精品一区二区三区八戒| 国产精品一区三区| 免费成人你懂的| 欧美精品啪啪| 久久精品夜色噜噜亚洲aⅴ| 久久人人爽爽爽人久久久| 日韩一级精品| 午夜精品成人在线视频| 亚洲精品国产精品乱码不99 | 欧美一站二站| 欧美91精品| 欧美一级播放| 欧美精品一区二区三区视频| 性欧美超级视频| 美女网站在线免费欧美精品| 亚洲午夜未删减在线观看| 欧美中文字幕在线播放| 一区二区欧美日韩| 老司机67194精品线观看| 亚洲欧美精品中文字幕在线| 蜜桃久久av| 久久国产免费看| 欧美日韩一级黄| 欧美电影在线观看| 国产亚洲一区二区精品| 亚洲精品视频中文字幕| 一区二区三区中文在线观看| 亚洲系列中文字幕| 在线视频日本亚洲性| 鲁大师成人一区二区三区| 久久国产精品久久w女人spa| 欧美全黄视频| 亚洲国产精品毛片| 亚洲第一页中文字幕| 欧美一区二区视频在线观看2020| 中文av字幕一区| 欧美黄色小视频| 欧美国产日韩二区| 在线播放豆国产99亚洲| 欧美在线视频日韩| 久久精品成人一区二区三区| 国产精品成人观看视频免费| 亚洲美女中出| 日韩视频在线永久播放| 欧美成人黄色小视频| 欧美高清hd18日本| 在线观看日韩国产| 久久精品中文字幕一区二区三区| 欧美一区二区三区在线观看视频| 国产精品免费在线| 亚洲一区尤物| 久久成人这里只有精品| 国产乱码精品| 欧美一进一出视频| 久久久久高清| 尤物99国产成人精品视频| 久久久久www| 亚洲第一视频网站| 亚洲免费成人av| 欧美日韩性视频在线| 亚洲午夜高清视频| 欧美一区亚洲| 狂野欧美激情性xxxx欧美| 亚洲肉体裸体xxxx137| 久久精品视频免费播放| 久久综合九色| 亚洲精品国产精品国产自| 欧美激情一区二区三区不卡| 日韩午夜在线| 亚洲欧美激情一区| 韩曰欧美视频免费观看| 蜜桃av一区二区| 一卡二卡3卡四卡高清精品视频| 亚洲欧美清纯在线制服| 国产一区二区观看| 欧美高清自拍一区| 亚洲一区二区在线免费观看视频 | 黄色亚洲精品| 欧美日本久久| 欧美一区二区三区四区高清| 欧美18av| 亚洲在线免费| 亚洲电影视频在线| 欧美色欧美亚洲另类二区| 欧美在线免费观看亚洲| 亚洲国产精品一区二区www| 亚洲婷婷综合久久一本伊一区| 国产日韩欧美一区二区| 裸体素人女欧美日韩| 亚洲小说区图片区| 蜜臀av一级做a爰片久久| 亚洲一区二区三区成人在线视频精品| 国产亚洲精品久久久| 欧美日本成人| 久久欧美肥婆一二区| 亚洲一区欧美二区| 欧美大片免费看| 久久精品日韩| 亚洲午夜国产一区99re久久| 在线成人激情| 国产欧美一区二区精品性| 欧美久久久久久蜜桃| 久久久五月天| 久久av红桃一区二区小说| 99re8这里有精品热视频免费| 久久免费视频一区| 午夜精品在线| 一区二区三区久久久| 亚洲国产影院| 一区三区视频| 红桃视频亚洲| 国产一区二区在线观看免费| 国产精品久久久久久久久久尿| 欧美大片一区| 美女精品一区| 欧美va天堂在线| 久久综合给合| 久久久成人精品| 性伦欧美刺激片在线观看| 中文精品视频一区二区在线观看| 亚洲欧洲精品一区二区| 你懂的国产精品| 欧美成人亚洲成人| 牛牛影视久久网| 欧美成人在线免费观看| 免费久久99精品国产自在现线| 久久久久高清| 免费国产一区二区| 另类欧美日韩国产在线| 牛牛精品成人免费视频| 欧美大片免费观看在线观看网站推荐| 久久青草久久| 欧美高清视频| 亚洲欧洲一区二区三区| 亚洲另类视频| 99在线精品免费视频九九视| 一本高清dvd不卡在线观看| 99国产精品99久久久久久粉嫩| 亚洲日本欧美| 在线亚洲+欧美+日本专区| 亚洲一区二区三区激情| 校园春色国产精品| 久久九九国产| 欧美精品在线观看播放| 国产精品久久久99| 国产一区二区三区丝袜| 亚洲福利国产| 中文国产一区| 久久久噜噜噜久久中文字幕色伊伊| 久久久精品国产免费观看同学| 猛干欧美女孩| 亚洲精品一区二区在线| 亚洲一区图片| 免费成人av资源网| 欧美视频在线看| 国内成人精品一区| 亚洲精品免费在线| 羞羞答答国产精品www一本| 你懂的国产精品永久在线| 亚洲毛片视频| 欧美一区=区| 欧美日韩国产在线观看| 国产精品你懂得| 91久久极品少妇xxxxⅹ软件| 亚洲一区日本| 欧美黑人在线播放| 亚洲免费一区二区| 欧美国产日韩一区| 国产视频一区欧美| 夜色激情一区二区| 久久五月激情| 在线一区二区三区四区| 狼人天天伊人久久| 国产精品永久在线| 99视频精品| 久久一区中文字幕| 亚洲免费视频在线观看| 欧美激情小视频| 伊人久久大香线蕉av超碰演员| 中文欧美在线视频| 亚洲电影免费观看高清完整版在线| 亚洲一区二区精品|