码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • 数据结构学习笔记(6)--特殊矩阵的压缩存储


    1.数组的存储结构

    (1)一维数组的存储结构

    起始地址:LOC

    各数组元素大小相同,且物理上连续存放。

    数组元素a[i]的存放地址=LOC+i*sizeof(ElemType)    (0<=i<10)

    注:除非题目特别说明,否则数组下标默认从0开始。

    (2)二维数组的存储结构

    M行N列的二维数组b[M][N]中,

    若按行优先存储,则b[i][j]的存储地址=LOC+(i*N+j)*sizeof(ElemType);

    若按列优先存储,则b[i][j]的存储地址=LOC+(j*M+i)* sizeof(ElemType).

    2.特殊矩阵的存储

    (1)对称矩阵的压缩存储

    策略:只存储主对角线+下三角区

    按行优先原则将各元素存入一维数组中,该一维数组的长度应该设置为(1+n)*n/2。

    key:按行优先的原则,a[i][j]是第i(i-1)/2+j个元素,数组下标k=i(i-1)/2+j-1(数组下标从0开始)

    ai,j存储在一维数组中对应B[k]

    k=i(i-1)/2+j-1,i>=j(下三角区和主对角线元素)

    k=j(j-1)/2+i-1,i

    (2)三角矩阵的压缩存储

    压缩存储策略:按行优先原则先将下三角存入一维数组中,并在最后一个位置存储常量c

    一维数组的长度:n(n+1)/2+1

    ①上三角区是常数

    ai,j转B[k],k=i(i-1)/2+j-1,i>=j(下三角区和主对角线元素)

    k=n(n+1)/2,i

    ②下三角区是常数

    ai,j转B[k],k=(i-1)(2n-i+2)/2+(j-i),j<=j(上三角区和主对角线元素)

    k=n(n+1)/2,i>j(下三角区元素)

    (3)三对角矩阵的压缩存储

    三对角矩阵,又称带状矩阵:

    当|i-j|>1时,有ai,j = 0(1<=i,j<=n)

    压缩存储策略:

    按行优先(或按列优先)原则,只存储带状部分

    一维数组的长度:3n-2

    前i-1行共3(i-1)-1个元素

    ai,j是i行第j-i+2个元素

    ai,j是第2i+j+2个元素

    ai,j转B[k],k=2i+j-3

    (4)稀疏矩阵的压缩矩阵

    稀疏矩阵:非零元素远远少于矩阵元素的个数

    压缩存储策略:链式存储--十字链表法

  • 相关阅读:
    第五章:最新版零基础学习 PYTHON 教程—Python 字符串操作指南(第四节 - Python 中的字符串反转6种不同的方式方法)
    Kafka - This server does not host this topic-partition
    前端开发面试题—Vue的生命周期
    vue基础语法01
    句法解析CoreNLPDependencyParser
    使用Windbg排查线程死锁引起的连不上服务器问题
    网络版本计算器(再谈“协议“)
    HTML中的pre标签
    《Nature》论文插图的Matlab复刻第4期—单组多色柱状图(Part2-82)
    网络编程——BIO与NIO介绍与底层原理
  • 原文地址:https://blog.csdn.net/2301_81135589/article/details/139248230
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号