线性方程组的迭代法(Jacobi 迭代法和Gauss-Seidel 迭代法) C++代码

2023-12-01 09:01

本文主要是介绍线性方程组的迭代法(Jacobi 迭代法和Gauss-Seidel 迭代法) C++代码,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

Jacobi 迭代法

#include <iostream>
#include <cmath>
#include <vector>using namespace std;// 定义方程组的系数矩阵和常数向量
vector<vector<double>> A = {{20, 2, 3},{1, 8, 1},{2, -3, 15}};
vector<double> b = {24, 12, 30};// 定义迭代次数和精度阈值
int maxIterations = 100;
double epsilon = 5e-5;
int iterations = 0;
// 雅可比迭代函数
vector<double> jacobiIteration(const vector<vector<double>>& A, const vector<double>& b, const vector<double>& x0) {int n = A.size();vector<double> x(x0);  // 初始解的近似值for (int k = 0; k < maxIterations; k++) {iterations++;vector<double> x_new(n, 0);for (int i = 0; i < n; i++) {double sum = 0;for (int j = 0; j < n; j++) {if (j != i) {sum += A[i][j] * x[j];}}x_new[i] = (b[i] - sum) / A[i][i];}// 判断是否满足终止条件double diff = 0;for (int i = 0; i < n; i++) {diff += abs(x_new[i] - x[i]);}if (diff < epsilon) {break;}// 更新解的近似值x = x_new;}return x;
}int main() {int n = A.size();vector<double> x0(n, 0);  // 初始解的近似值vector<double> x = jacobiIteration(A, b, x0);cout << "Solution: \n";for (int i = 0; i < n; i++) {cout << "x" << i+1 << " = " << x[i] << "\n";}cout << endl;cout << "iterations = " << iterations << '\n';return 0;
}

Gauss-Seidel 迭代法

#include <iostream>
#include <cmath>#define N 3 // 线性方程组的未知数个数
#define MAX_ITERATIONS 100 // 最大迭代次数
#define EPSILON 0.00005 // 迭代停止的精度void gaussSeidel(double coef[N][N], double b[N], double x[N]) {double x_new[N];// 初始化迭代结果for (int i = 0; i < N; i++) {x[i] = 0;}int iterations = 0;double error = EPSILON + 1;while (error > EPSILON && iterations < MAX_ITERATIONS) {for (int i = 0; i < N; i++) {double sum1 = 0;for (int j = 0; j < i; j++) {sum1 += coef[i][j] * x_new[j];}double sum2 = 0;for (int j = i + 1; j < N; j++) {sum2 += coef[i][j] * x[j];}x_new[i] = (b[i] - sum1 - sum2) / coef[i][i];}error = 0;for (int i = 0; i < N; i++) {error += std::abs(x_new[i] - x[i]);x[i] = x_new[i];}iterations++;}if (iterations < MAX_ITERATIONS) {std::cout << "Converged in " << iterations << " iterations." << std::endl;} else {std::cout << "Did not converge within the maximum number of iterations." << std::endl;}
}int main() {double coef[N][N] = {{20, 2, 3}, {1, 8, 1}, {2, -3, 15}};double b[N] = {24, 12, 30};double x[N];gaussSeidel(coef, b, x);std::cout << "Solution:" << std::endl;for (int i = 0; i < N; i++) {std::cout << "x" << i << " = " << x[i] << std::endl;}return 0;
}

Jacobi 迭代法与Gauss-Seidel 迭代法的比较

#include <iostream>
#include <vector>
#include <cmath>#define N 3 // 线性方程组的未知数个数
#define MAX_ITERATIONS 100 // 最大迭代次数
#define EPSILON 0.00005 // 迭代停止的精度// 高斯-赛德尔迭代法
int gaussSeidel(const std::vector<std::vector<double>>& A, const std::vector<double>& b, std::vector<double>& x) {std::vector<double> x_new(N);// 初始化迭代结果for (int i = 0; i < N; i++) {x[i] = 0;}int iterations = 0;double error = EPSILON + 1;while (error > EPSILON && iterations < MAX_ITERATIONS) {for (int i = 0; i < N; i++) {double sum1 = 0;for (int j = 0; j < i; j++) {sum1 += A[i][j] * x_new[j];}double sum2 = 0;for (int j = i + 1; j < N; j++) {sum2 += A[i][j] * x[j];}x_new[i] = (b[i] - sum1 - sum2) / A[i][i];}error = 0;for (int i = 0; i < N; i++) {error += std::abs(x_new[i] - x[i]);x[i] = x_new[i];}iterations++;}return iterations;
}// 雅可比迭代法
int jacobi(const std::vector<std::vector<double>>& A, const std::vector<double>& b, std::vector<double>& x) {std::vector<double> x_new(N);// 初始化迭代结果for (int i = 0; i < N; i++) {x[i] = 0;}int iterations = 0;double error = EPSILON + 1;while (error > EPSILON && iterations < MAX_ITERATIONS) {for (int i = 0; i < N; i++) {double sum = 0;for (int j = 0; j < N; j++) {if (j != i) {sum += A[i][j] * x[j];}}x_new[i] = (b[i] - sum) / A[i][i];}error = 0;for (int i = 0; i < N; i++) {error += std::abs(x_new[i] - x[i]);x[i] = x_new[i];}iterations++;}return iterations;
}int main() {std::vector<std::vector<double>> A = {{20, 2, 3}, {1, 8, 1}, {2, -3, 15}};std::vector<double> b = {24, 12, 30};std::vector<double> x(N);int gaussSeidelIterations = gaussSeidel(A, b, x);int jacobiIterations = jacobi(A, b, x);std::cout << "Gauss-Seidel iterations: " << gaussSeidelIterations << std::endl;std::cout << "Jacobi iterations: " << jacobiIterations << std::endl;return 0;
}

这篇关于线性方程组的迭代法(Jacobi 迭代法和Gauss-Seidel 迭代法) C++代码的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/440537

相关文章

Windows下C++使用SQLitede的操作过程

《Windows下C++使用SQLitede的操作过程》本文介绍了Windows下C++使用SQLite的安装配置、CppSQLite库封装优势、核心功能(如数据库连接、事务管理)、跨平台支持及性能优... 目录Windows下C++使用SQLite1、安装2、代码示例CppSQLite:C++轻松操作SQ

C++中RAII资源获取即初始化

《C++中RAII资源获取即初始化》RAII通过构造/析构自动管理资源生命周期,确保安全释放,本文就来介绍一下C++中的RAII技术及其应用,具有一定的参考价值,感兴趣的可以了解一下... 目录一、核心原理与机制二、标准库中的RAII实现三、自定义RAII类设计原则四、常见应用场景1. 内存管理2. 文件操

C++中零拷贝的多种实现方式

《C++中零拷贝的多种实现方式》本文主要介绍了C++中零拷贝的实现示例,旨在在减少数据在内存中的不必要复制,从而提高程序性能、降低内存使用并减少CPU消耗,零拷贝技术通过多种方式实现,下面就来了解一下... 目录一、C++中零拷贝技术的核心概念二、std::string_view 简介三、std::stri

C++高效内存池实现减少动态分配开销的解决方案

《C++高效内存池实现减少动态分配开销的解决方案》C++动态内存分配存在系统调用开销、碎片化和锁竞争等性能问题,内存池通过预分配、分块管理和缓存复用解决这些问题,下面就来了解一下... 目录一、C++内存分配的性能挑战二、内存池技术的核心原理三、主流内存池实现:TCMalloc与Jemalloc1. TCM

Python实例题之pygame开发打飞机游戏实例代码

《Python实例题之pygame开发打飞机游戏实例代码》对于python的学习者,能够写出一个飞机大战的程序代码,是不是感觉到非常的开心,:本文主要介绍Python实例题之pygame开发打飞机... 目录题目pygame-aircraft-game使用 Pygame 开发的打飞机游戏脚本代码解释初始化部

C++ 函数 strftime 和时间格式示例详解

《C++函数strftime和时间格式示例详解》strftime是C/C++标准库中用于格式化日期和时间的函数,定义在ctime头文件中,它将tm结构体中的时间信息转换为指定格式的字符串,是处理... 目录C++ 函数 strftipythonme 详解一、函数原型二、功能描述三、格式字符串说明四、返回值五

Java中Map.Entry()含义及方法使用代码

《Java中Map.Entry()含义及方法使用代码》:本文主要介绍Java中Map.Entry()含义及方法使用的相关资料,Map.Entry是Java中Map的静态内部接口,用于表示键值对,其... 目录前言 Map.Entry作用核心方法常见使用场景1. 遍历 Map 的所有键值对2. 直接修改 Ma

C++作用域和标识符查找规则详解

《C++作用域和标识符查找规则详解》在C++中,作用域(Scope)和标识符查找(IdentifierLookup)是理解代码行为的重要概念,本文将详细介绍这些规则,并通过实例来说明它们的工作原理,需... 目录作用域标识符查找规则1. 普通查找(Ordinary Lookup)2. 限定查找(Qualif

深入解析 Java Future 类及代码示例

《深入解析JavaFuture类及代码示例》JavaFuture是java.util.concurrent包中用于表示异步计算结果的核心接口,下面给大家介绍JavaFuture类及实例代码,感兴... 目录一、Future 类概述二、核心工作机制代码示例执行流程2. 状态机模型3. 核心方法解析行为总结:三

python获取cmd环境变量值的实现代码

《python获取cmd环境变量值的实现代码》:本文主要介绍在Python中获取命令行(cmd)环境变量的值,可以使用标准库中的os模块,需要的朋友可以参考下... 前言全局说明在执行py过程中,总要使用到系统环境变量一、说明1.1 环境:Windows 11 家庭版 24H2 26100.4061