Python程序判断给定矩阵是否为稀疏矩阵

王林
发布: 2023-09-05 14:57:07
转载
1627人浏览过

python程序判断给定矩阵是否为稀疏矩阵

矩阵是一个矩形数组,其中一组数字按行和列排列。它被称为 m X n 矩阵,其中 m 和 n 是维度。

如果矩阵包含的非零元素数量少于零元素,则称为稀疏矩阵

[0, 0, 3, 0, 0]
[0, 1, 0, 0, 6]
[1, 0, 0, 9, 0]
[0, 0, 2, 0, 0]
登录后复制

上面的矩阵是 4X5 矩阵,这里大部分数字都是零。只有少数元素非零,因此我们可以将其视为稀疏矩阵。

要检查给定矩阵是否是稀疏矩阵,我们需要比较元素和零的总数。如果零元素的个数超过矩阵中元素的一半。那么我们可以将给定的矩阵称为稀疏矩阵。

立即学习Python免费学习笔记(深入)”;

(m * n)/2
登录后复制

让我们讨论一下确定给定矩阵是否为稀疏矩阵的不同方法。

使用 For 循环

使用 for 循环,我们可以轻松地迭代 python 中的数组元素。

示例

首先,我们将迭代矩阵行并计算每行中存在的零的数量。然后计数值将存储在计数器变量中。

之后,我们将计数器变量中的值与矩阵中的一半元素进行比较,以确定给定矩阵是否是稀疏矩阵。

OmniAudio
OmniAudio

OmniAudio 是一款通过 AI 支持将网页、Word 文档、Gmail 内容、文本片段、视频音频文件都转换为音频播客,并生成可在常见 Podcast ap

OmniAudio 111
查看详情 OmniAudio
def isSparse(array, m, n):
   counter = 0
   # Count number of zeros
   for i in range(0, m):
      for j in range(0, n):
         if (array[i][j] == 0):
            counter = counter + 1
   return (counter > ((m * n) // 2))

arr = [[0, 0, 3],
       [0, 0, 0],
       [1, 8, 0]]

print("The original matrix: ")
for row in arr:
   print(row)
print()

# check if the given matrix is sparse matrix or not
if (isSparse(arr, len(arr), len(arr[0]))):
   print("The given matrix is a sparse matrix")
else:
   print("The given matrix is not a sparse matrix")
登录后复制

输出

The original matrix: 
[0, 0, 3]
[0, 0, 0]
[1, 8, 0]

The given matrix is a sparse matrix
登录后复制

上面的矩阵是一个稀疏矩阵。

示例

在此示例中,我们将使用 list.count() 方法来计算循环中每行的零个元素,并将计数存储在计数器变量中。

def isSparse(array, m, n):
   counter = 0
   # Count number of zeros
   for i in array:
      counter += i.count(0)
   return (counter > ((m * n) // 2))

arr = [[0, 0, 3],
       [0, 0, 0],
       [1, 8, 0]]

print("The original matrix: ")
for row in arr:
   print(row)
print()

# check if the given matrix is sparse matrix or not
if (isSparse(arr, len(arr), len(arr[0]))):
   print("The given matrix is a sparse matrix")
else:
   print("The given matrix is not a sparse matrix")
登录后复制

输出

The original matrix: 
[0, 0, 3]
[0, 0, 0]
[1, 8, 0]

The given matrix is a sparse matrix
登录后复制

使用 SciPy 库

通过使用 Python 中的 SciPy 库,我们可以创建稀疏矩阵。在下面的示例中,我们使用 csr_matrix() 函数以压缩稀疏行格式创建稀疏矩阵。

issparse()函数用于检查给定对象是否是稀疏矩阵。

示例

最初,我们将使用嵌套列表创建一个数组,然后使用 csr_matrix() 方法将其转换为稀疏矩阵。

from scipy.sparse import issparse, csr_matrix
arr = [[0, 0, 3],
       [0, 0, 0],
       [1, 8, 0]]

matrix = csr_matrix(arr)

print("The original matrix: ")
print(matrix)
print()

# check if the given matrix is sparse matrix or not
if (issparse(matrix)):
   print("The given matrix is a sparse matrix")
else:
   print("The given matrix is not a sparse matrix")
登录后复制

输出

The original matrix: 
  (0, 2)	3
  (2, 0)	1
  (2, 1)	8

The given matrix is a sparse matrix
登录后复制

csr_matrix() 方法仅将数据点(非零元素)存储在内存中。

注意 - issparse() 方法与输入矩阵有多少元素无关。相反,它检查给定对象是否是 spmatrix 的实例。

以上就是Python程序判断给定矩阵是否为稀疏矩阵的详细内容,更多请关注php中文网其它相关文章!

相关标签:
python速学教程(入门到精通)
python速学教程(入门到精通)

python怎么学习?python怎么入门?python在哪学?python怎么学才快?不用担心,这里为大家提供了python速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:tutorialspoint网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号