目录
对角占优矩阵
示例
问题陈述
方法一:暴力破解
算法
方法二:排序
方法3:行缩放
结论
首页 web前端 js教程 对角占优矩阵的 JavaScript 程序

对角占优矩阵的 JavaScript 程序

Aug 27, 2023 pm 01:53 PM

对角占优矩阵的 JavaScript 程序

矩阵是计算机科学和数学中的重要工具,可用于快速逼近困难的计算。矩阵是按行和列组织的数字的集合,可以表示数据或数学问题。

通过本文,我们将了解对角显性矩阵。我们将研究对角占优矩阵的概念、算法和示例,以及它们在各种编程语言中的实现。

对角占优矩阵

如果对于矩阵中的每一行,行中对角项的大小大于或等于所有非对角项的大小之和,我们可以称方矩阵为对角占优。简单来说,如果矩阵中除对角元素以外的元素之和小于对角矩阵。

如果我们有一个包含 i 行和 j 列的方阵 a,我们可以使用数学方程将其表示为对角占优矩阵 -

$$mathrm{|:a_{ii}:|:geq:displaystylesumlimits_{j

eq:i}:|:a_{ij} |}$$ 为我所有 其中 aij 表示第 i 列和第 j 列中的条目

示例

A = [ [6, -2, 0, 0],
   [2, 8, -3, 0],
   [1, 2, 9, -4],
   [0, 1, -2, 7]
]
登录后复制

该矩阵是对角占优的,因为它满足以下条件 -

|a11| ≥ |a12| + |a13| + |a14| == |+6| ≥ |+2| + |+1| + |+0|
|a22| ≥ |a21| + |a23| + |a24| == |+8| ≥ |+2| + |+3| + |+0|
|a33| ≥ |a31| + |a32| + |a34| == |+9| ≥ |+1| + |+2| + |+4|
|a44| ≥ |a41| + |a42| + |a43| == |+7| ≥ |+0| + |+1| + |+2|
登录后复制

问题陈述

给定一个方阵,编写一个 JavaScript 程序来检查该矩阵是否对角占优。

示例

让我们考虑一个 3x3 矩阵 -

| 4 -1 0 |
| -1 4 -1|
| 0 -1 4 |
登录后复制

这里,每一行的对角线元素分别为4、4和4,它们都大于该行其他元素的绝对值之和。因此,该矩阵是对角占优的。

现在让我们看看解决上述问题的方法。

方法一:暴力破解

暴力法包括迭代矩阵的每一行并确定对角元素是否大于该行中其他元素的绝对值之和。

算法

  • 迭代矩阵的行。

  • 计算每行中其他分量的绝对值之和。

  • 检查该行的对角线元素是否大于或等于步骤 2 中确定的总和。

  • 如果对角线元素大于或等于总和,则继续迭代到下一行。

  • 如果对角线元素小于总和,则返回 false,表明该矩阵不是对角占优的。

示例

<!DOCTYPE html>
<html>
<body>
   <div id="matrix"></div>
   <div id="output"></div>
   <script>
      function isDiagonallyDominant(matrix) {
         const rows = matrix.length;
         const cols = matrix[0].length;
         for(let i = 0; i < rows; i++) {
            let sum = 0;
            for(let j = 0; j < cols; j++) {
               if(i !== j) {
                  sum += Math.abs(matrix[i][j]);
               }
            }
            if(Math.abs(matrix[i][i]) < sum) {
               return false;
            }
         }
         return true;
      }
      const matrix = [[4, -1, 0], [-1, 4, -1], [0, -1, 4]];
      const output = isDiagonallyDominant(matrix) ? 'Matrix is diagonally dominant.' : 'Matrix is not diagonally dominant.';
      document.getElementById('matrix').innerHTML = 'Matrix: ' + JSON.stringify(matrix);
      document.getElementById('output').innerHTML = 'Output: ' + output;
   </script>
</body>
</html>
登录后复制

时间复杂度:O(n2),其中 n 是矩阵的大小。

方法二:排序

在此方法中,我们按降序对每行的绝对值进行排序。然后我们确定该行的对角线元素是否大于或等于最大的 n-1 个绝对值之和,其中 n 是矩阵的大小。

算法

  • 迭代矩阵的行。

  • 按降序对行项目的绝对值进行排序。

  • 添加最大的 n-1 个绝对值,其中 n 是矩阵的大小。

  • 检查该行的对角线元素是否大于或等于步骤 3 中确定的总和。

  • 如果对角线元素大于或等于总和,则继续迭代到下一行。

  • 如果对角线元素小于总和,则返回 false,表明该矩阵不是对角占优的。

示例

<!DOCTYPE html>
<html>
<body>
   <h2>Diagonally Dominant Matrix</h2>
   <p id="matrix"></p>
   <p id="output"></p>
   <script>
      function isDiagonallyDominant(matrix) {
         const rows = matrix.length;
         const cols = matrix[0].length;
         for(let i = 0; i < rows; i++) {
            const sortedRow = matrix[i].map(Math.abs).sort((a, b) => b - a);
            const sum = sortedRow.slice(1, cols).reduce((acc, val) => acc + val, 0);
            if(sortedRow[0] < sum) {
               return false;
            }
         }
         return true;
      }

      // Example matrix
      const matrix = [[4, -1, 0], [-1, 4, -1], [0, -1, 4]];

      // Display input matrix
      const matrixElement = document.getElementById("matrix");
      matrixElement.innerHTML = "Input Matrix: <br>" + JSON.stringify(matrix);

      // Check if the matrix is diagonally dominant
      const isDominant = isDiagonallyDominant(matrix);

      // Display output
      const outputElement = document.getElementById("output");
      outputElement.innerHTML = "Is diagonally dominant: " + isDominant;
   </script>
</body>
</html>
登录后复制

时间复杂度:O(n2 log n),其中 n 是矩阵的大小。

方法3:行缩放

在此方法中,我们首先缩放矩阵的每一行,使其对角线元素等于 1。然后我们查看该行中其他条目的绝对值是否小于 1。

算法

  • 迭代矩阵的行。

  • 识别具有最高绝对值的行。

  • 缩放行直到对角线元素等于 1。

  • 检查该行中剩余条目的绝对值是否小于 1。

  • 如果所有行都满足步骤 4 中的标准,则返回 true,表明矩阵对角占优。

  • 如果任意行不满足步骤4的要求,则返回false,表明该矩阵不是对角占优的。

示例

<!DOCTYPE html>
<html>
<body>
   <h3>Diagonally Dominant Matrix</h3>
   <p>Matrix:</p>
   <pre id="matrix">

Is diagonally dominant:

<script> function isDiagonallyDominant(matrix) { const rows = matrix.length; const cols = matrix[0].length; for(let i = 0; i < rows; i++) { const maxAbsVal = Math.max(...matrix[i].map(Math.abs)); if(maxAbsVal === 0) { return false; } const scale = 1 / maxAbsVal; for(let j = 0; j < cols; j++) { matrix[i][j] *= scale; } const sum = matrix[i].slice(0, i).reduce((acc, val) => acc + Math.abs(val), 0) + matrix[i].slice(i+1, cols).reduce((acc, val) => acc + Math.abs(val), 0); if(sum >= 1) { return false; } } return true; } const matrix = [[4, -1, 0], [-1, 4, -1], [0, -1, 4]]; document.getElementById('matrix').innerHTML = matrix.map(row => row.join(' ')).join(''); document.getElementById('output').innerHTML = isDiagonallyDominant(matrix) ? 'true' : 'false'; </script>
登录后复制

时间复杂度:O(n3),其中 n 是矩阵的大小。

结论

在这篇博客中,我们讨论了一个通过各种方法来查找矩阵是否对角占优的程序。其中一些使用循环、排序和行缩放方法。希望您发现此信息有用。

以上是对角占优矩阵的 JavaScript 程序的详细内容。更多信息请关注PHP中文网其他相关文章!

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

AI Hentai Generator

AI Hentai Generator

免费生成ai无尽的。

热门文章

R.E.P.O.能量晶体解释及其做什么(黄色晶体)
2 周前 By 尊渡假赌尊渡假赌尊渡假赌
仓库:如何复兴队友
4 周前 By 尊渡假赌尊渡假赌尊渡假赌
Hello Kitty Island冒险:如何获得巨型种子
4 周前 By 尊渡假赌尊渡假赌尊渡假赌

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

在JavaScript中替换字符串字符 在JavaScript中替换字符串字符 Mar 11, 2025 am 12:07 AM

JavaScript字符串替换方法详解及常见问题解答 本文将探讨两种在JavaScript中替换字符串字符的方法:在JavaScript代码内部替换和在网页HTML内部替换。 在JavaScript代码内部替换字符串 最直接的方法是使用replace()方法: str = str.replace("find","replace"); 该方法仅替换第一个匹配项。要替换所有匹配项,需使用正则表达式并添加全局标志g: str = str.replace(/fi

自定义Google搜索API设置教程 自定义Google搜索API设置教程 Mar 04, 2025 am 01:06 AM

本教程向您展示了如何将自定义的Google搜索API集成到您的博客或网站中,提供了比标准WordPress主题搜索功能更精致的搜索体验。 令人惊讶的是简单!您将能够将搜索限制为Y

构建您自己的Ajax Web应用程序 构建您自己的Ajax Web应用程序 Mar 09, 2025 am 12:11 AM

因此,在这里,您准备好了解所有称为Ajax的东西。但是,到底是什么? AJAX一词是指用于创建动态,交互式Web内容的一系列宽松的技术。 Ajax一词,最初由Jesse J创造

示例颜色json文件 示例颜色json文件 Mar 03, 2025 am 12:35 AM

本文系列在2017年中期进行了最新信息和新示例。 在此JSON示例中,我们将研究如何使用JSON格式将简单值存储在文件中。 使用键值对符号,我们可以存储任何类型的

10个jQuery语法荧光笔 10个jQuery语法荧光笔 Mar 02, 2025 am 12:32 AM

增强您的代码演示:开发人员的10个语法荧光笔 在您的网站或博客上共享代码片段是开发人员的常见实践。 选择合适的语法荧光笔可以显着提高可读性和视觉吸引力。 t

8令人惊叹的jQuery页面布局插件 8令人惊叹的jQuery页面布局插件 Mar 06, 2025 am 12:48 AM

利用轻松的网页布局:8个基本插件 jQuery大大简化了网页布局。 本文重点介绍了简化该过程的八个功能强大的JQuery插件,对于手动网站创建特别有用

10 JavaScript和JQuery MVC教程 10 JavaScript和JQuery MVC教程 Mar 02, 2025 am 01:16 AM

本文介绍了关于JavaScript和JQuery模型视图控制器(MVC)框架的10多个教程的精选选择,非常适合在新的一年中提高您的网络开发技能。 这些教程涵盖了来自Foundatio的一系列主题

什么是这个&#x27;在JavaScript? 什么是这个&#x27;在JavaScript? Mar 04, 2025 am 01:15 AM

核心要点 JavaScript 中的 this 通常指代“拥有”该方法的对象,但具体取决于函数的调用方式。 没有当前对象时,this 指代全局对象。在 Web 浏览器中,它由 window 表示。 调用函数时,this 保持全局对象;但调用对象构造函数或其任何方法时,this 指代对象的实例。 可以使用 call()、apply() 和 bind() 等方法更改 this 的上下文。这些方法使用给定的 this 值和参数调用函数。 JavaScript 是一门优秀的编程语言。几年前,这句话可

See all articles