CSDN

先说说什么叫稀疏矩阵。

你说,

这个问题很简单吗,

那你一定不知道中国学术界的嘴皮子仗,

对一个字眼的“抠”将会导致两种相反的结论。这是清华

2000

年的一道考研题:“表示一个有

1000

个顶点,

1000

条边的有向图的邻接矩阵有多少个矩阵元素?是否稀疏矩阵?”

如果你是个

喜欢研究出题者心理活动的人,

你可以看出这里有两个陷阱,

就是让明明会的人答错,

我不想说

出是什么,留给读者思考。姑且不论清华给的标准答案是什么,

那年的参考书是严蔚敏的《数据

结构(

C

语言版)》,书上对于稀疏矩阵的定义是这样的:“非零元较零元少(注:原书下文给

出了大致的程度)

且分布没有一定规律”

照这个说法,

那题的答案应该是不一定是稀疏矩阵,

因为可能是特殊矩阵

(非零元分布有规律)

自从

2002

年换参考书后,

很多概念都发生了变化,

最明显的是从多少开始计数(

0

还是

1

),从而导致的是空树的高度变成了-

1

,只有一个根节

点的树高度是

0

。很不幸的是树高的问题几乎年年都考,在你下笔的时候,总是犯点嘀咕,总不

是一朝天子一朝臣吧,

会不会答案是个兼容版本?然后,

新参考书带的习题集里引用了那道考研

题,答案是是稀疏矩阵。你也许会惊讶这年头咸鱼都会游泳了,

但这个答案和书并不矛盾,

因为

在这本黄皮书里,根本就没有什么特殊矩阵,

自然就一定是稀疏矩阵了。

其实,

这两本书在这个

问题上也没什么原则上的问题,

C

版的是从数据结构实现区分出特殊矩阵和稀疏矩阵,

毕竟他们

实现起来很不相同;

新书一股脑把非零元少的矩阵都当成稀疏矩阵,

当你按照这种思路做的时候

就会发现,

各种结构特殊的非零元很少的矩阵,

如果用十字链表来储存的话,

比考虑到它的特殊

结构得出的特有储存方法,

仅仅是浪费了几个表头节点和一些指针域,

再有就是一些运算效率的

降低。从我个人角度讲,我更喜欢多一些统一,少一些特别,即使牺牲一点效率;所以在这一点

上我赞同新参考书的做法。而在计数起点上,我更喜欢原来的做法;毕竟,研究数据结构要考虑

人的思考习惯,

而不是计算机喜欢什么;

你非得说表中的第一个元素是第

0

个,

空树的高是-

1

怎么不让人心里起疙瘩。

数据结构是人们构造算法时思维和计算机实现的桥梁、

中介,

它应该符

合人的思考习惯,

即使在它实现的时候内部做了某些转换。

开始废话了这么多,

希望没打消了你

往下看的心情,好,言归正传。

这里的十字链表是这样构成的:

用链表模拟矩阵的行

(或者列,

这可以根据个人喜好来定)

然后,

再构造代表列的链表,

将每一行中的元素节点插入到对应的列中去。

书中为了少存几个表

头节点,将行和列的表头节点合并到了一起——实际只是省了几个指针域,如果行和列数不等,

多余的数据域就把这点省出的空间又给用了。

这点小动作让我着实废了半天劲,

个人感觉,

优点

不大,

缺点不少,

不如老老实实写得象个十字链表,

让人也好看一些,

这是教科书,

目的是教学。

实在看得晕的人,参阅

C

版的这部分内容,很清晰。我也不会画图,打个比方吧:这个十字链

表的逻辑结构就像是一个围棋盘(没见过,你就想一下苍蝇拍,这个总见过吧)

,而非零元就好

像是在棋盘上放的棋子,

总共占的空间就是,

确定那些线的表头节点和那些棋子代表的非零元节

点。最后,我们用一个指针指向这个棋盘,这个指针就代表了这个稀疏矩阵。

现在,让我们看看非零元节点最少需要哪几个域,

data

必须的,

down

right

把线画下去,

好像不需要别的了。再看看表头节点,由于是链表的表头节点,

所以就和后边的节点一样了。

后,

行链表和列链表的表头节点实际上也各构成了一个链表,

我们给他们添加一个公有的表头节

点。

最后,

通过指向这个行列链表表头构成的链表的公有的表头节点的指针,

我们就可以访问稀

疏矩阵了。

好像和书上的不一样——非零元节点没了指示位置的

I

j

,实际上,对于确定非零元在矩阵

中的位置,

I

j

不是必须的,看着围棋盘你就会很清楚。但是很不幸,不是把他们存起来就万事

大吉了,最起码,必须考虑加法和乘法的效率,请你想想如果用上面的那种结构,如何完成。考

noj数据结构稀疏矩阵的加法十字链表_数据结构学习(C )稀疏矩阵(十字链表1)相关推荐

  1. java静态链表_数据结构笔记:静态链表(C语言)

    void CreateList(StaticLinkList *P)//创建一个静态链表 { int i; for(i=0;i此时并没有已占用空间,所以第一个节点中的指针(cur)的值为1,也就是说空 ...

  2. java静态链表_用Java实现一个静态链表

    什么是静态链表? 对于线性链表,也可用一维数组来进行描述.这种描述方法便于在没有指针类型的高级程序设计语言中使用链表结构. 用数组描述的链表,即称为静态链表. 在C语言中,静态链表的表现形式即为结构体 ...

  3. 等待链表_调度(准备运行)链表

    文章目录 前奏 等待链表 调度(等待被调用)链表 版本差异 总结: 跨进程操作 前奏 对于进程断链,程序可以正常运行,原因是CPU执行与调度是基于线程的,进程断链只是影响一些遍历系统进程的API,并不 ...

  4. noj数据结构稀疏矩阵的加法十字链表_数据结构之:图

    导读 1. 什么是图?图的存储方式? 2. 图的遍历(深度优先搜索,广度优先搜索) 3. 最短路径 1. 什么是图?图的存储方式? 前面总结了"树"这种数据结构,而这篇博客总结的是 ...

  5. java环形链表_数据结构和算法(四)Java实现环形链表

    1. 数据结构和算法(四)Java实现环形链表 1.1 约瑟夫问题 约瑟夫问题:公元66年,约瑟夫不情愿地参与领导了犹太同胞反抗罗马统治的起义,后来起义失败,他和一些宁死不降的起义者被困于一个山洞之中 ...

  6. java城市链表_数据结构城市链表 1. 城市链表 [问题描述]将若干城市的信息 联合开发网 - pudn.com...

    数据结构城市链表 所属分类:文章/文档 开发工具:Java 文件大小:174KB 下载次数:7 上传日期:2017-12-18 18:37:53 上 传 者:叁佰 说明:  1. 城市链表 [问题描述 ...

  7. 数据结构java实验 刘小晶_数据结构实例解析与实验指导:Java语言描述

    部分 知识提炼与实例解析 章 绪论 1.1 数据结构的基本概念 1.1.1 知识提炼 1.1.2 典型实例解析 1.1.3 实例练习 1.2 算法与算法分析 1.2.1 知识提炼 1.2.2 典型实例 ...

  8. s数据结构替换子表java版_数据结构与算法分析Java语言描述(第3版) PDF和源码免费 下载...

    <数据结构与算法分析Java语言描述(第3版)>PDF和源码免费 下载 免积分下载 用户下载说明: 图书简介: 数据结构:Java语言描述(原书第3版)是国外数据结构与算法分析方面的经典教 ...

  9. c++ 链表_算法学习笔记 - 链表 - 单链表的粗糙实现

    常用的链表有单链表.双链表.循环链表. 概念看得再多,理解得再多,也不一定能够写得出来.所以动动手,多练习才是提升能力的关键. 有朋友留言说道:建议大家在实现之前的思考时间不要太长.一是先用自己能想到 ...

最新文章

  1. 地图构建两篇顶级论文解析
  2. Scrum 团队成立 -- 软件工程
  3. IC/RFID/NFC 关系与区别
  4. TL-410小路由静态路由问题
  5. 进程——Windows核心编程学习手札系列之四
  6. 程序员面试题精选100题(52)-C++面试题(1)
  7. formate JAVA_JAVA String.format 方法使用
  8. linux之Vim使用
  9. 聚焦2020云栖大会 边缘计算专场畅谈技术应用创新
  10. 理解卷积神经网络的利器:9篇重要的深度学习论文(上)
  11. pandas 读取某一单元格的值_一个参数一个Excel表,让你玩转Pandas中read_excel()表格读取!...
  12. (篇八)C语言在母串删子串、输入位置截取子串
  13. 使用CPU时间戳进行高精度计时
  14. C++_类和对象_对象特性_深拷贝与浅拷贝---C++语言工作笔记044
  15. Android中CursorLoader的使用、原理及注意事项
  16. 第128篇 智能合约改进(ERC721)
  17. ASCII码对照表 包含二进制、十进制、十六进制
  18. noi linux,NOI Linux使用教程(基础讲解)
  19. Java基础 day08笔记
  20. ipv6解析地理位置

热门文章

  1. 建议给予导师决定硕博士能否毕业的自主权?教育部:将充分采纳!
  2. 华为阿里下班时间曝光:所有的光鲜,都有加班的味道...
  3. 改进张益唐证明,陶哲轩「他的证明比我还强」,这个天才青年还解决了困扰数学界近80年的「简单问题」...
  4. 博士称因待遇不公要离职,被学校要求返还51万元补偿费
  5. 清华学生总结的算法学习方法
  6. 深度学习先驱Bengio:AI顶会论文的Deadline是时候取消了
  7. 科学界最牛的合影在这,能认全的都是大神!
  8. python进程执行带有参数的任务(args、kwargs)
  9. 卷起来了,写了一套Tensorflow和Pytorch的教程
  10. 使用Numpy实现PCA