线性方程组的迭代法(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;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/185410.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

brat文本标注工具——安装

目录 一、Linux系统安装 1. centOS系统 2. Ubuntu系统 3. macOS系统 4.说明 二、Google Chrome安装 1. 打开命令行&#xff0c;切换到管理者权限 2. 安装依赖 3. 下载Google浏览器的安装包 4. 安装Google Chrome 三、yum更新 四、Apache安装 安装Apache 启动Apac…

threeJs引入模型使用3D模型(vite+React+Ts)

要在 Three.js 中使用 3D 模型&#xff0c;你需要加载模型文件并将其添加到场景中。Three.js 支持多种不同的模型格式&#xff0c;比如 OBJ、FBX、GLTF 等。 init vitelatest //创建一个vite的脚手架 选择react并配置Ts 安装three.js准备 npm install react-three/drei np…

a-select:远程搜索——防抖节流处理——基础积累

a-select:远程搜索——防抖节流处理——基础积累 效果图下拉筛选数据&#xff1a;远程搜索功能&#xff1a; 效果图 下拉筛选数据&#xff1a; <a-selectshow-searchv-model"form.jobPositionCode"placeholder"请选择岗位"style"width: 100%"…

Redis哈希对象(listpack介绍)

哈希对象的编码可以是ziplist或者hashtable。再redis5.0版本之后出现listpack&#xff0c;为了是代替ziplist。 一. 使用ziplist编码 ziplist编码的哈希对象使用压缩列表作为底层实现&#xff0c;每当有新的键值对要加入到哈希对象时&#xff0c;程序都会先将保存了键值对的键…

【Linux 静态IP配置】

静态IP配置 1.NAT模式设置2.设置静态ip3.重启网络4.查看ip 1.NAT模式设置 首先设置虚拟机中NAT模式的选项&#xff0c;打开VMware&#xff0c;点击“编辑”下的“虚拟网络编辑器”&#xff0c;设置NAT参数 注意&#xff1a; VMware Network Adapter VMnet8保证是启用状态 …

ClassCMS2.4漏洞复现

ClassCMS2.4漏洞复现 环境搭建 任意文件下载漏洞复现 漏洞成因 ClassCMS2.4漏洞复现 CMS源码在附件中 环境搭建 使用phpstudy2016搭建web环境&#xff0c;php版本为5.5 安装CMS 这里选择Mysql数据库进行安装 用户名和密码都写默认的admin方便记忆 输入完成后点击安装 点…

【性能测试】性能测试监控关键指标

系统指标 检测性能测试是否有bug的关键指标 1、系统指标——与用户场景及需求直接相关。 并发用户数&#xff1a;某一物理时刻同时向系统提交请求的用户数。平均响应时间&#xff1a;系统处理事务的响应时间的平均值&#xff0c;对于系统快速响应类页面&#xff0c;一般响应…

货代FOB条款卖方必备的知识:发货人都要承担哪些费用呢?

据统计&#xff0c;中国出口中以FOB成交的占到70%&#xff0c;但专家指出&#xff1a;FOB对出口商的风险更大&#xff0c;有可能造成货、款两空的结局。 目前我国出口合同以FOB价格条款成交的比例越来越大&#xff0c;而且收货人指定船公司的少&#xff0c;指定境外货代的多&am…

koa2项目jwt结合jsonwebtoken进行加密和验签

1.创建项目 koa-generator快速生成koa项目 koa2 admin-server npm install -g koa-generator koa2 admin-server npm install npm run dev启动服务 2.token设置 app.js引入koa-jwt和jsonwebtoken npm i koa-jwt npm i jsonwebtoken 引入路由文件&#xff1b;对没有验签通…

阻止事件冒泡

在默认情况下&#xff0c;发生在一个子元素上的单击事件&#xff08;或者其他事件&#xff09;&#xff0c;如果在其父级元素绑定了一个同样的事件&#xff0c;此时点击子元素&#xff0c;click事件会首先被子元素捕获&#xff0c;执行绑定的事件程序&#xff0c;之后会被父级元…

建设银行新余市分行积极开展国债下乡宣传活动

近日&#xff0c;为了普及国债知识&#xff0c;提高农村居民对国债的认知度和投资意识&#xff0c;建设银行新余市分行组织员工前往下村开展了一场国债下乡宣传活动。 活动当天&#xff0c;工作人员早早地来到了下乡地点&#xff0c;悬挂起了国债宣传横幅&#xff0c;并摆放了…

ESP32-Web-Server编程- 使用SSE 实时更新设备信息

ESP32-Web-Server编程- 使用SSE 实时更新设备信息 概述 如前所述&#xff0c;传统 HTTP 通信协议基于 Request-Apply&#xff08;请求-响应&#xff09;机制&#xff0c;浏览器&#xff08;客户端&#xff09;只能单向地向服务器发起请求&#xff0c;服务器无法主动向浏览器推…

1.7 java实现License认证信息的加密解密处理

java实现License认证信息的加密解密处理 一、什么是License认证二、确定License文件的格式和内容1. 生成一个存放License信息的ini文件 三、使用RSA非对称加密方式对文件进行加密和解密1. 生成密钥对2. 加密数据3. 解密数据 一、什么是License认证 License认证是一种用于验证软…

java源码-数组

背景 上传图片&#xff0c;需要对图片格式进行校验&#xff0c;这是就可以使用数组 1、什么是数组&#xff1f; Java 语言中提供的数组是用来存储固定大小的同类型元素。 如&#xff1a;可以声明一个数组变量&#xff0c;如 numbers[100] 来代替直接声明 100 个独立变量 numb…

替代升级虚拟化 | ZStack Cloud云平台助力中节能镇江公司核心业务上云

数字经济正加速推动各行各业的高质量升级发展&#xff0c;云计算是数字经济的核心底层基础设施。作为云基础软件企业&#xff0c;云轴科技ZStack 坚持自主创新&#xff0c;自研架构&#xff0c;产品矩阵可全面覆盖数据中心云基础设施&#xff0c;针对虚拟化资源实现纳管、替代和…

用按层次顺序遍历二叉树的方法,设计算法统计树中度为1的结点数目

用按层次顺序遍历二叉树的方法&#xff0c;设计算法统计树中度为1的结点数目 代码思路&#xff1a; 层序遍历的实现需要借助一个辅助队列 首先将根结点入队&#xff0c;然后根出队&#xff0c;把根的两个子树入队 然后下面循环执行&#xff1a;队头元素出队&#xff0c;队头元…

如何通过降低设备六大损失帮助企业改善OEE

在各个行业中&#xff0c;改善设备综合效率OEE&#xff08;Overall Equipment Efficiency&#xff09;是企业实现高效生产和竞争优势的关键。然而&#xff0c;设备的六大损失常常影响着企业的OEE指标。本文将探讨如何通过降低这六大损失来帮助企业改善OEE&#xff0c;提高生产效…

2023年掌控安全学院CTF暖冬杯——数据流分析

前言&#xff1a;打工仔一枚&#xff0c;第一波上新的3题misc 做完了 再打ISCTF随便记录一下 PS&#xff1a;环境关了&#xff0c;题目描述忘记了&#xff0c;反正就是找flag。 筛选HTTP数据流 导出数据流慢慢看 ctrl F 搜flag 看到一条 有flag.txt 的数据 导出另存.zip 这里…

洗袜子的洗衣机哪款好?内衣洗衣机便宜好用的牌子

不得不说洗衣机的发明解放了我们的双手&#xff0c;而我们从小到大就有这个意识&#xff0c;贴身衣物不可以和普通的衣服一起丢进去洗衣机一起&#xff0c;而内衣裤上不仅有肉眼看见的污渍还有手上根本无法消灭的细菌&#xff0c;但是有一款专门可以将衣物上的细菌杀除的内衣洗…

java设计模式学习之【建造者模式】

文章目录 引言建造者模式简介定义与用途实现方式&#xff1a; 使用场景优势与劣势建造者模式在spring中的应用CD&#xff08;光盘&#xff09;的模拟示例UML 订单系统的模拟示例UML 代码地址 引言 建造者模式在创建复杂对象时展现出其强大的能力&#xff0c;特别是当这些对象需…