目录
输入
输出
说明
天真的方法
示例
时间和空间复杂度
高效的方法
结论
首页 web前端 js教程 检查矩阵是否对称的 JavaScript 程序

检查矩阵是否对称的 JavaScript 程序

Aug 27, 2023 pm 03:37 PM

检查矩阵是否对称的 JavaScript 程序

对称矩阵是矩阵的特殊情况,其中矩阵和矩阵的转置都相同。矩阵是一组以矩形形式存储的整数或数字,相当于二维数组,矩阵的转置也是将所有行替换为列得到的矩阵。我们将得到一个矩阵,并且必须打印它是否是对称矩阵。

输入

Mat = [[1, 2, 3],
	   [2, 3, 8],
	   [3, 8, 0]]
登录后复制

输出

Yes, the given matrix is the symmetric matrix. 
登录后复制

说明

众所周知,转置矩阵是将列替换为行、将行替换为列的矩阵,因此这里第一行与第一列相同,第二行与列相同,第三行与列相同也是一样的。

输入

Mat = [[1, 2, 3],
	   [2, 3, 9],
	   [3, 8, 0]]
登录后复制

输出

No, the given matrix is not a symmetric matrix. 
登录后复制

说明

在给定的矩阵中,转置矩阵将是 -

Trans: [[1, 2, 3],
	    [2, 3, 8],
	    [3, 9, 0]]
登录后复制

我们可以看到第二行和第三行或者第二列和第三列不一样。

注意 - 正如我们所见,给定矩阵的转置可以通过交换行和列来形成,这意味着如果矩阵的维度为 N*M,则矩阵的维度为转置矩阵将为 M*N。这意味着要使矩阵成为对称矩阵,N 必须等于 M,从而得到方阵。

天真的方法

在这种方法中,我们首先通过创建一个新矩阵并按行列存储元素来获取转置矩阵。然后我们将简单地遍历两个矩阵并比较它们。如果它们在任何索引处不匹配,那么我们将返回 false,否则我们将返回 true。

示例

// function to find the transpose of the given matrix
function getTranspose(mat){   
 
   // getting the number of rows present in the given matrix. 
   var n = mat.length; 
   
   // getting the number of columns present in the given matrix. 
   var m = mat.length;   
   
   // creating a new array to store the transpose matrix 
   
   // new array will have m rows and n columns 
   var transP = new Array(m) 
   
   // traversing over the given matrix column-wise 
   for(var i = 0;i < m; i++){
      var cur = new Array(n);
      for(var j = 0; j<n; j++){
         cur[j] = mat[j][i];
      }
      transP[i] = cur;
   }
   
   // returing tranpose of the given matrix 
   return transP;
}

// function to check if the given matrix is symmetric or not
function check(mat){
   var n = mat.length;
   var m = mat[0].length;
   
   // matrix must be a square matrix 
   if(n != m){
      return false;
   }    
   
   // getting tranpose of the given matrix 
   var transP = getTranspose(mat);  
   
   // checking if both matrices are equal
   for(var i = 0; i<n ;i++){
      for(var j = 0; j<n ;j++){
         if(mat[i][j] != transP[i][j]){
            return false;
         }
      }
   }
   return true;
}

// defining the matrix 
var mat = [[1, 2, 3],
           [2, 3, 8],
           [3, 8, 0]]
console.log("The given matrix is: ")
console.log(mat);
if(check(mat)){
   console.log("The given matrix is a symmetric matrix")
}
else{
   console.log("The given matrix is not a symmetric matrix")
}
登录后复制

时间和空间复杂度

上述代码的时间复杂度为 O(N*N),其中 N 是给定矩阵的大小。

上述代码的空间复杂度为 O(N*N),因为我们使用额外的空间来存储转置矩阵元素。

高效的方法

转置矩阵可以通过交换行和列得到,即每一列等于对应的行。因此,任何索引 (i,j) 处的值都将等于给定矩阵中 (j,i) 处的值。

示例

// function to check if the given matrix is symmetric or not
function check(mat){
   var n = mat.length;
   var m = mat[0].length;  
   
   // matrix must be a square matrix 
   if(n != m){
      return false;
   }  
   
   // checking if mat[i][j] is equal to mat[j][i] or not
   for(var i = 0; i<n ;i++){
      for(var j = 0; j<i ;j++){
         if(mat[i][j] != mat[j][i]){
            return false;
         }
      }
   }
   return true;
}

// defining the matrix 
var mat = [[1, 2, 3],
           [2, 3, 8],
           [3, 9, 0]]
console.log("The given matrix is: ")
console.log(mat);
if(check(mat)){
   console.log("The given matrix is a symmetric matrix")
}
else{
   console.log("The given matrix is not a symmetric matrix")
}
登录后复制

时间和空间复杂度

上述代码的时间复杂度为 O(N*N),其中 N 是给定矩阵的大小。

上述代码的空间复杂度为 O(1),因为我们没有使用任何额外的空间。

结论

在上面的教程中,我们实现了一段 JavaScript 代码来查找给定的矩阵是否是对称矩阵。对称矩阵是矩阵的特殊情况,其中矩阵和矩阵的转置都相同,并且矩阵的转置可以通过交换行和列来获得。矩阵必须是方阵才能成为对称矩阵。我们实现了两种方法,时间复杂度为 O(N*N),空间复杂度为 O(N*N),空间复杂度为 O(1)。

以上是检查矩阵是否对称的 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.能量晶体解释及其做什么(黄色晶体)
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳图形设置
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您听不到任何人,如何修复音频
3 周前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解锁Myrise中的所有内容
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 18, 2025 pm 03:12 PM

文章讨论了创建,发布和维护JavaScript库,专注于计划,开发,测试,文档和促销策略。

如何在浏览器中优化JavaScript代码以进行性能? 如何在浏览器中优化JavaScript代码以进行性能? Mar 18, 2025 pm 03:14 PM

本文讨论了在浏览器中优化JavaScript性能的策略,重点是减少执行时间并最大程度地减少对页面负载速度的影响。

前端热敏纸小票打印遇到乱码问题怎么办? 前端热敏纸小票打印遇到乱码问题怎么办? Apr 04, 2025 pm 02:42 PM

前端热敏纸小票打印的常见问题与解决方案在前端开发中,小票打印是一个常见的需求。然而,很多开发者在实...

如何使用浏览器开发人员工具有效调试JavaScript代码? 如何使用浏览器开发人员工具有效调试JavaScript代码? Mar 18, 2025 pm 03:16 PM

本文讨论了使用浏览器开发人员工具的有效JavaScript调试,专注于设置断点,使用控制台和分析性能。

如何使用源地图调试缩小JavaScript代码? 如何使用源地图调试缩小JavaScript代码? Mar 18, 2025 pm 03:17 PM

本文说明了如何使用源地图通过将其映射回原始代码来调试JAVASCRIPT。它讨论了启用源地图,设置断点以及使用Chrome DevTools和WebPack之类的工具。

如何有效地使用Java的收藏框架? 如何有效地使用Java的收藏框架? Mar 13, 2025 pm 12:28 PM

本文探讨了Java收藏框架的有效使用。 它强调根据数据结构,性能需求和线程安全选择适当的收集(列表,设置,地图,队列)。 通过高效优化收集用法

初学者的打字稿,第2部分:基本数据类型 初学者的打字稿,第2部分:基本数据类型 Mar 19, 2025 am 09:10 AM

掌握了入门级TypeScript教程后,您应该能够在支持TypeScript的IDE中编写自己的代码,并将其编译成JavaScript。本教程将深入探讨TypeScript中各种数据类型。 JavaScript拥有七种数据类型:Null、Undefined、Boolean、Number、String、Symbol(ES6引入)和Object。TypeScript在此基础上定义了更多类型,本教程将详细介绍所有这些类型。 Null数据类型 与JavaScript一样,TypeScript中的null

开始使用Chart.js:PIE,DONUT和BUBBLE图表 开始使用Chart.js:PIE,DONUT和BUBBLE图表 Mar 15, 2025 am 09:19 AM

本教程将介绍如何使用 Chart.js 创建饼图、环形图和气泡图。此前,我们已学习了 Chart.js 的四种图表类型:折线图和条形图(教程二),以及雷达图和极地区域图(教程三)。 创建饼图和环形图 饼图和环形图非常适合展示某个整体被划分为不同部分的比例。例如,可以使用饼图展示野生动物园中雄狮、雌狮和幼狮的百分比,或不同候选人在选举中获得的投票百分比。 饼图仅适用于比较单个参数或数据集。需要注意的是,饼图无法绘制值为零的实体,因为饼图中扇形的角度取决于数据点的数值大小。这意味着任何占比为零的实体

See all articles