日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

瀏覽:27日期:2022-08-22 17:50:15

補(bǔ)充知識(shí):

正定矩陣

奇異矩陣

嚴(yán)格對(duì)角占優(yōu)

要理解Gauss消去法,首先來(lái)看一個(gè)例子:

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

從上例子可以看出,高斯消去法實(shí)際上就是我們初中學(xué)的階二元一次方程組,只不過(guò)那里的未知數(shù)個(gè)數(shù)$n=2$

$n>2$時(shí),Gauss消去法的思路實(shí)際上和解二元一次方程組是一樣的,方法如下:

將n方程組中的n−1個(gè)方程通過(guò)消元,形成一個(gè)與原方程組等價(jià)的一個(gè)新方程組,新方程組中的n−1個(gè)方程僅包含n−1個(gè)未知數(shù)。 故問(wèn)題就轉(zhuǎn)化為了求解n−1元的方程組,這樣我們可以繼續(xù)消元,以次類推,直到最后一個(gè)方程組為一元一次方程組 從最后一個(gè)一元一次方程組求解出最后一個(gè)未知量,然后逐步回代入之前的方程組,從而得到所有的未知數(shù)。 我們可以看到Gauss實(shí)際上就分為兩步:消去和回代

下面通過(guò)一般化得到Gauss消元法的求解過(guò)程

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

以上就是Gauss消去法的基本步驟,我們?cè)倩剡^(guò)頭看看有沒(méi)有什么問(wèn)題?

我們?cè)谇蟊壤?l_{ik}= frac{a_{ik}^{left (k-1 right )}}{a_{kk}^{left (k-1 right )}}$時(shí),如果分母很小,即:

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

$l_{ik}rightarrow infty$,那么

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

總結(jié)一下,能否使用Gauss消元法的情況

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

為了解決這個(gè)問(wèn)題,我們可以使用列主元Gauss消元法。

如何基于java實(shí)現(xiàn)Gauss消元法過(guò)程解析

參考了一些網(wǎng)上的代碼,這里給出Gauss的Java實(shí)現(xiàn)

package peterxiazhe;import java.util.Scanner;public class Gauss { /** * 列主元高斯消去法 */ static double A[][]; static double b[]; static double x[]; static int n; //n表示未知數(shù)的個(gè)數(shù) static int n_2; //記錄換行的次數(shù) public static void main(String[] args) { System.out.println('--------------輸入方程組未知數(shù)的個(gè)數(shù)---------------'); Scanner sc = new Scanner(System.in); n = sc.nextInt();A = new double[n][n]; b = new double[n]; x = new double[n];System.out.println('--------------輸入方程組的系數(shù)矩陣A:---------------'); for(int i = 0; i < n; i++) { for(int j = 0; j < n; j++) {A[i][j] = sc.nextDouble(); } }System.out.println('--------------輸入方程組的常量向量b:---------------'); for(int i = 0; i < n; i++) {b[i] = sc.nextDouble(); }Elimination(); BackSubstitution(); PrintRoot(); } //消元法 public static void Elimination() { PrintA(); for(int k = 0; k < n; k++) { WrapRow(k); for(int i = k+1; i < n; i++) {double l = A[i][k] / A[k][k];A[i][k] = 0;for(int j = k+1; j < n; j++) { A[i][j] = A[i][j] - l * A[k][j];}b[i] = b[i] - l * b[k]; } //System.out.println('第' + k + '次消元后:'); //PrintA(); } } //回代法 public static void BackSubstitution() { x[n-1] = b[n-1] / A[n-1][n-1]; for(int i = n - 2; i >= 0; i--) { x[i] = (b[i] - solve(i)) / A[i][i]; } } public static double solve(int i) { double result = 0.0; for(int j = i; j < n; j++) result += A[i][j] * x[j]; return result; } //輸出方程組的根 public static void PrintRoot() { System.out.println('--------------方程組的根為---------------'); for(int i = 0; i < n; i++) { System.out.println('x' + (i+1) + ' = ' + x[i]); } } //交換Swap函數(shù)??? public static void Swap(double[] ar, int x, int y) { Double tmp = ar[x]; ar[x] = ar[y]; ar[y] = tmp; } public static void PrintA() { //輸出A的增廣矩陣 //System.out.println('--------------增廣矩陣---------------'); for(int i = 0; i < n; i++) { for(int j = 0; j < n; j++) {System.out.print(A[i][j] + ' '); } System.out.println(b[i]); } } //交換矩陣的行 public static void WrapRow(int k) { //k表示第k+1輪消元 double maxElement = Math.abs(A[k][k]);int WrapRowIndex = k; // 記住要交換的行 for(int i = k + 1; i < n; i++) { if (Math.abs(A[i][k]) > maxElement) {WrapRowIndex = i;maxElement = A[i][k]; } } if (WrapRowIndex != k) { //交換求得最大主元 n_2 += 1; System.out.println('k = ' + k + '時(shí),' + '要交換的行為' + k + '和'+ WrapRowIndex); //先交換A for(int j = k; j < n; j++) {double[] arr = {A[k][j], A[WrapRowIndex][j]};Swap(arr, 0, 1);A[k][j] = arr[0]; A[WrapRowIndex][j] = arr[1];//double tmp = A[k][j];//A[k][j] = A[WrapRowIndex][j];//A[WrapRowIndex][j] = tmp; } //再交換b double[] arr = {b[k], b[WrapRowIndex]}; Swap(arr, 0, 1); b[k] = arr[0]; b[WrapRowIndex] = arr[1];// double tmp = b[k];// b[k] = b[WrapRowIndex];// b[WrapRowIndex] = tmp; System.out.println('--------------交換后---------------'); PrintA(); } }}

注意:由于Java不支持對(duì)基本數(shù)據(jù)類型的引用傳遞,這里使用了一個(gè)小技巧

java中交換兩個(gè)基本數(shù)據(jù)類型的變量函數(shù)swap(int[] source,int i,int j)

java中函數(shù)的參數(shù)傳遞機(jī)制是:基本數(shù)據(jù)類型采用值傳遞,對(duì)象采用傳引用。因此,如果要寫一個(gè)交換兩個(gè)int型變量數(shù)值的函數(shù),還真是有點(diǎn)不方便,必須采用一個(gè)數(shù)組對(duì)象來(lái)作為輔助,具體實(shí)現(xiàn)如下:

//交換兩個(gè)整數(shù) private static void swap(int[] source, int i, int j) { int temp = source[i]; source[i] = source[j]; source[j] = temp; }

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Java
相關(guān)文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
亚洲视频综合| 欧美成a人片免费观看久久五月天| 日韩一区精品视频| 免费人成网站在线观看欧美高清| 91精品一区国产高清在线gif| 国产精品免费精品自在线观看| 欧美日韩色图| 高潮一区二区| 国产在线不卡一区二区三区| 免费在线欧美黄色| 国产精品日本| 日韩午夜av在线| 欧美日韩一区二区综合| 久久精品成人| 蜜臀va亚洲va欧美va天堂| 中文久久精品| 日韩在线卡一卡二| 中文字幕人成乱码在线观看| 国产一区二区三区探花| 久久午夜影院| 亚洲国产成人二区| 99精品视频在线观看免费播放| 色老板在线视频一区二区| 日韩伦理一区| 不卡福利视频| 欧美激情福利| 国产极品嫩模在线观看91精品| 日韩av网站在线免费观看| 视频一区欧美日韩| 蜜桃91丨九色丨蝌蚪91桃色| 日本成人在线一区| 麻豆精品99| 亚洲黄色免费看| 国产伊人精品| 日韩精品一区第一页| 日韩av黄色在线| 麻豆视频久久| 欧美日韩中文字幕一区二区三区| 尤物在线精品| 亚洲欧洲免费| 丝瓜av网站精品一区二区| 在线免费观看亚洲| 国产精品最新自拍| 国产精品久久久久久妇女| 麻豆精品视频在线观看免费| 最近高清中文在线字幕在线观看1| 欧美少妇精品| 蜜臀久久99精品久久久久久9| 日本亚洲最大的色成网站www | 国产精品国产一区| 国产国产精品| 日韩有吗在线观看| 国产精品永久| 免费久久精品| 日韩av电影一区| 国产精品一区二区中文字幕| av资源亚洲| 免费在线视频一区| 精品国产亚洲日本| 99热免费精品| 国际精品欧美精品| 中文日韩在线| 中文字幕av一区二区三区四区| 国精品一区二区三区| 亚洲青青久久| 精品捆绑调教一区二区三区| 久久午夜精品| 999精品色在线播放| 精品视频高潮| 麻豆国产欧美一区二区三区| 天堂va欧美ⅴa亚洲va一国产| 精品一区欧美| 国产精品久久久久av电视剧| 国产高清精品二区| 亚洲精选久久| 女人天堂亚洲aⅴ在线观看| 久久99精品久久久野外观看| 五月亚洲婷婷 | 国产模特精品视频久久久久| 亚洲午夜91| 丰满少妇一区| 久久精品99久久久| 久久九九99| 亚洲影视一区二区三区| 日本一二区不卡| 日韩中出av| 国产精品99一区二区| 精品国产亚洲一区二区三区大结局| 综合亚洲自拍| 青草久久视频| 青草av.久久免费一区| 丁香婷婷久久| 天海翼亚洲一区二区三区| 免费在线观看一区| 中文字幕免费一区二区| 日韩成人综合| 黄色精品视频| 精品三级在线观看视频| 91成人在线| 91精品国产自产在线丝袜啪| 亚洲精品国产精品粉嫩| 欧美日韩亚洲一区| 国产欧美精品久久| 亚洲视频二区| 一区二区三区四区精品视频| 亚洲在线免费| 日韩精品免费一区二区夜夜嗨| 国产乱码精品一区二区亚洲| 欧美一区二区三区高清视频| 国产精品丝袜在线播放| 日本视频一区二区| 国产欧美日韩在线一区二区| 国产一区二区三区不卡视频网站| 久久影视三级福利片| 不卡av一区二区| 亚洲最新av| 欧美激情福利| 99tv成人| 欧美女激情福利| 欧美日韩色图| 精品欧美日韩精品| 成人亚洲一区| 亚洲精品影院在线观看| 91麻豆精品激情在线观看最新| 日韩欧美精品一区| 亚洲精品动态| 欧美成人基地 | 最新日韩欧美| 久久最新视频| 久久精品三级| 久久一区精品| 国产精品呻吟| 国产精品蜜月aⅴ在线| 91视频久久| 日韩1区2区3区| 日韩在线观看不卡| 国产精品多人| 亚洲深夜福利在线观看| 黄色精品视频| 免费在线观看日韩欧美| 久久不见久久见国语| 久久一级电影| 日韩欧美自拍| 国产极品模特精品一二| 亚洲免费观看高清完整版在线观| 国产一区视频在线观看免费| 97精品资源在线观看| 亚洲一级黄色| 91成人福利| 亚洲成人一区在线观看| 欧美精品成人| 美女视频免费精品| 日本一区二区免费高清| 97精品视频在线看| 中文在线中文资源| 久久激情一区| 国产精品玖玖玖在线资源| 欧美成人久久| 国产欧美大片| 国产精品一站二站| 久久亚洲精品中文字幕| 国产欧美日韩在线一区二区| 国产一区二区视频在线看| 欧美国产免费| 国产欧美日韩一区二区三区在线| 婷婷综合五月| 91精品一区国产高清在线gif | 尹人成人综合网| 韩国久久久久久| 91tv亚洲精品香蕉国产一区| 亚洲国产日韩欧美在线| 免费精品国产| 影音国产精品| 欧美午夜不卡影院在线观看完整版免费| 国内精品亚洲| 日本一二区不卡| 天堂а√在线最新版中文在线| 日本久久二区| 91亚洲无吗| 激情视频一区二区三区| 精品视频在线观看网站| 久久精品一本| 99久久亚洲精品| 国产91在线播放精品| 91亚洲无吗| 日韩综合在线| 国产一区二区三区免费在线| 91成人网在线观看| 日本国产亚洲| 亚洲精品1区| 日韩一区二区三区精品| 美女精品久久| 91精品国产乱码久久久久久久| 蜜臀久久99精品久久久久久9| 国产一区二区三区四区五区传媒| 一区二区不卡| 麻豆精品网站| 国产精品香蕉| 亚洲综合电影| 蘑菇福利视频一区播放|