当前位置: 首页 > news >正文

盐城专业做网站的公司哪家好seo推广外包企业

盐城专业做网站的公司哪家好,seo推广外包企业,南宁网站建设哪家,西安小程序制作稀疏矩阵是一种特殊类型的矩阵,其中大多数元素都是零。由于稀疏矩阵中非零元素的数量远少于零元素,因此可以使用特定的数据结构和算法来高效地存储和处理它们,从而节省存储空间和计算时间。 RowPtr 数组中的每个元素表示对应行的第一个非零元…

 稀疏矩阵是一种特殊类型的矩阵,其中大多数元素都是零。由于稀疏矩阵中非零元素的数量远少于零元素,因此可以使用特定的数据结构和算法来高效地存储和处理它们,从而节省存储空间和计算时间。

RowPtr 数组中的每个元素表示对应行的第一个非零元素在 Values 数组中的位置。最后一个元素表示整个 Values 数组的长度,用来标识矩阵的结束位置。

这个矩阵中非零元素只有 5 个,其余元素都是零,因此这个矩阵可以被认为是稀疏矩阵。

存储方法:

为了节省空间,稀疏矩阵常用以下几种常见的存储方法:

  1. 压缩行存储(Compressed Row Storage, CRS)

    用三个一维数组来存储稀疏矩阵:

    • Values:存储非零元素的值。
    • Column:存储对应非零元素的列索引。
    • RowPtr:存储每一行的起始位置在 Values 数组中的索引。

    例如,对于上面的矩阵 A:

    • Values 存储所有的非零元素 [3, 22, 17, 8, 6]
    • Column 存储每个非零元素所在的列 [2, 0, 4, 2, 1]
    • RowPtr 存储每行第一个非零元素在 Values 中的索引 [0, 1, 3, 3, 4, 5]。其中最后一个值 5 是用来标识最后一行的结束位置。
  2. 压缩列存储(Compressed Column Storage, CCS)

    这个方法类似于 CRS,但按列存储:

    • Values:存储非零元素的值。
    • Row:存储对应非零元素的行索引。
    • ColPtr:存储每一列的起始位置在 Values 数组中的索引。

应用场景:

稀疏矩阵广泛应用于以下领域:

  • 科学计算:如有限元分析、计算流体力学等。
  • 机器学习:如推荐系统中的用户-物品矩阵。
  • 图论:如图的邻接矩阵表示。

使用稀疏矩阵的特定存储方法和算法可以大大提高计算的效率和节省存储空间。

如何构建稀疏矩阵存储

Step 1: Values 和 Column 数组

先确定 ValuesColumn 数组:

  • 第一行:非零元素是 3,位置在第 3 列

    • Values = [3]
    • Column = [2]
  • 第二行:非零元素是 22 和 17,位置分别在第 1 列和第 5 列

    • Values = [3, 22, 17]
    • Column = [2, 0, 4]
  • 第三行:没有非零元素

    • ValuesColumn 数组保持不变
    • Values = [3, 22, 17]
    • Column = [2, 0, 4]
  • 第四行:非零元素是 8,位置在第 3 列

    • Values = [3, 22, 17, 8]
    • Column = [2, 0, 4, 2]
  • 第五行:非零元素是 6,位置在第 2 列

    • Values = [3, 22, 17, 8, 6]
    • Column = [2, 0, 4, 2, 1]
Step 2: RowPtr 数组

计算每行的起始位置:

  • 第一行:第一个非零元素在 Values 的位置是 0,因此 RowPtr[0] = 0
  • 第二行:第一个非零元素在 Values 的位置是 1,因此 RowPtr[1] = 1
  • 第三行:没有非零元素,RowPtr[2] 应该和前一行的结束位置相同(第二行的结束位置是 RowPtr[1] + 第二行的非零元素个数 = 1 + 2 = 3
  • 第四行:第一个非零元素在 Values 的位置是 3,因此 RowPtr[3] = 3
  • 第五行:第一个非零元素在 Values 的位置是 4,因此 RowPtr[4] = 4
  • 结束位置Values 数组的长度是 5,所以 RowPtr[5] = 5

最终的存储数组

  • Values = [3, 22, 17, 8, 6]
  • Column = [2, 0, 4, 2, 1]
  • RowPtr = [0, 1, 3, 3, 4, 5]

解释每个值

  • RowPtr[0] = 0:第一行第一个非零元素在 Values 中的位置是 0
  • RowPtr[1] = 1:第二行第一个非零元素在 Values 中的位置是 1
  • RowPtr[2] = 3:第三行没有非零元素,起始位置和前一行的结束位置相同
  • RowPtr[3] = 3:第四行第一个非零元素在 Values 中的位置是 3
  • RowPtr[4] = 4:第五行第一个非零元素在 Values 中的位置是 4
  • RowPtr[5] = 5:表示整个矩阵的非零元素结束的位置(即 Values 数组的长度)

通过这种方式,RowPtr 数组帮助我们快速定位每一行在 Values 数组中的起始和结束位置,从而方便对稀疏矩阵进行高效操作。希望这样解释能帮助你更好地理解 RowPtr 数组的构建方法。

http://www.hkea.cn/news/484171/

相关文章:

  • 国内html5网站建设seo兼职工资一般多少
  • 青海西宁网站建设公司百度网络推广
  • 服装公司网站设计百度站长收录入口
  • 做搜索关键词任务网站网站维护是什么意思
  • 2018什么做网站百度网盘网页版入口
  • 深圳福田大型商城网站建设石家庄最新疫情最新消息
  • 网站版面结构chatgpt 网站
  • 网站后期推广是谁来做广州百度推广开户
  • 不上此网站枉做男人免费制作网站平台
  • 防红短链接生成佛山抖音seo
  • 网站建设php带数据库模板站长工具四叶草
  • 做网站客户拖着不验收店铺推广渠道有哪些方式
  • 站群系统哪个好用怎样进行seo推广
  • 淄博网站建设方案网络推广是做什么的
  • 网站建设销售工作职责seo平台怎么样
  • 免费的网站给一个百度seo优化服务项目
  • 现代广告创意设计郑州百度网站优化排名
  • 兰州网站建设哪家专业谷歌seo网站推广
  • 崇信门户网站留言回复上优化seo
  • 网站建设费用有哪些站长工具搜索
  • 云主机能干什么独立站seo怎么做
  • 苏州专业网站建设设计公司免费发布推广信息的b2b
  • 空间 两个网站网络推广培训班
  • 零基础学做网站推广公司简介
  • 公司做网站最好引擎搜索器
  • 济南手工网站建设北京百度seo服务
  • 网站建设原创百度seo官网
  • 徐州企业网站建设衡阳seo服务
  • 网站自然排名优化seo专员是什么职业
  • 视频网站制作广告代理公司