发表于: 2019-11-21 19:53:59

1 1085


今天做了什么

提前开了复盘(求学大作战), 照原型图大致写了下方案:

模块和接口:

签到:

点击签到

查看签到记录

签到页面展示用户信息

 

学生证:

微信个人信息授权

更改个人信息

查看收藏列表

后台管理获取用户信息

绑定手机

绑定邮箱

 

文学部:

获取文章列表

文章点赞

文章收藏

获取作者信息

查看单篇文章

 

文学部-文章管理后台:

新增

编辑

上下架

搜索

 

影像部:

视频分类搜索

展示视频详细信息

影像部-视频管理后台:

.

 

收获

数据结构:

物理结构:数据具体在内存中的存储. 顺序,链式,索引,哈希
逻辑结构:数据之间的相互关系. 集合,线性,树形,图状
数组: 数组是可以再内存中连续存储多个元素的结构,在内存中的分配也是连续的,数组中的元素通过数组下标进行访问,数组下标从0开始。

优点: 
1、按照索引查询元素速度快 
2、按照索引遍历数组方便
缺点: 
1、数组的大小固定后就无法扩容了 
2、数组只能存储一种类型的数据 
3、添加,删除的操作慢,因为要移动其他的元素。
适用于频繁查询,对存储空间要求不大,很少增加和删除的情况。
栈: 特殊的线性表, 仅能在线性表的一端操作,栈顶允许操作,栈底不允许操作。 栈的特点是:先进后出,或者说是后进先出,从栈顶放入元素的操作叫入栈,取出元素叫出栈。
常应用于实现递归功能方面的场景,例如斐波那契数列。

队列: 也是一种线性表,不同的是,队列可以在一端添加元素,在另一端取出元素,也就是:先进先出。从一端放入元素的操作称为入队,取出元素为出队
在多线程阻塞队列管理中非常适用

链表: 物理存储单元上非连续的、非顺序的存储结构,数据元素的逻辑顺序是通过链表的指针地址实现,每个元素包含两个结点,一个是存储元素的数据域 (内存空间),另一个是指向下一个结点地址的指针域。根据指针的指向,链表能形成不同的结构,例如单链表,双向链表,循环链表等。 
链表的优点:
链表是很常用的一种数据结构,不需要初始化容量,可以任意加减元素;
添加或者删除元素时只需要改变前后两个元素结点的指针域指向地址即可,所以添加,删除很快;
缺点:
因为含有大量的指针域,占用空间较大;
查找元素需要遍历链表来查找,非常耗时。
适用场景:
数据量较小,需要频繁增加,删除操作的场景
是一种数据结构,它是由n(n>=1)个有限节点组成一个具有层次关系的集合。把它叫做 “树” 是因为它看起来像一棵倒挂的树,也就是说它是根朝上,而叶朝下的。
    
二叉树是一种比较有用的折中方案,它添加,删除元素都很快,并且在查找方面也有很多的算法优化,所以,二叉树既有链表的好处,也有数组的好处,是两者的优化方案,在处理大批量的动态数据方面非常有用。
扩展:
二叉树有很多扩展的数据结构,包括平衡二叉树、红黑树、B+树等,这些数据结构二叉树的基础上衍生了很多的功能,在实际应用中广泛用到,例如mysql的数据库索引结构用的就是B+树,还有HashMap的底层源码中用到了红黑树。
哈希表
是根据关键码和值 (key和value) 直接进行访问的数据结构,通过key和value来映射到集合中的一个位置,这样就可以很快找到集合中的对应元素。
记录的存储位置=f(key)
这里的对应关系 f 成为散列函数,又称为哈希 (hash函数),而散列表就是把Key通过一个固定的算法函数既所谓的哈希函数转换成一个整型数字,然后就将该数字对数组长度进行取余,取余结果就当作数组的下标,将value存储在以该数字为下标的数组空间里,这种存储空间可以充分利用数组的查找优势来查找元素,所以查找的速度很快。
因为哈希表是基于数组衍生的数据结构,在添加删除元素方面是比较慢的,所以很多时候需要用到一种数组链表来做,也就是拉链法。拉链法是数组结合链表的一种结构,较早前的hashMap底层的存储就是采用这种结构,直到jdk1.8之后才换成了数组加红黑树的结构
堆中某个节点的值总是不大于或不小于其父节点的值;
堆总是一棵完全二叉树。
因为堆有序的特点,一般用来做数组中的排序,称为堆排序。
由结点的有穷集合V和边的集合E组成。其中,为了与树形结构加以区别,在图结构中常常将结点称为顶点,边是顶点的有序偶对,若两个顶点之间存在一条边,就表示这两个顶点具有相邻关系。
按照顶点指向的方向可分为无向图和有向图

遇到的问题


明天的计划

继续写后端方案.



返回列表 返回列表
评论

    分享到