很大部分转载自 https://blog.csdn.net/singit/article/details/54898316

数据的逻辑结构:反映数据元素之间的逻辑关系的数据结构,其中的逻辑关系指数据元素之间的前后件关系,而与他们在计算机中的存储位置无关。

逻辑结构包括:

  集合:数据结构中的元素之间除了“同属一个集合”的相互关系外,别无其他关系。

  线性结构:数据结构中的元素存在一对一的相互关系

  树形结构:数据结构中的元素存在一对多的相互关系

  图形结构:数据结构中的元素存在多对多的相互关系

数据的物理结构是数据结构在计算机中的表示,它包括数据元素的机内表示和关系的机内表示,由于具体实现的方法有顺序、链接、索引、散列等多种,所以,一种数据结构可表示成一种或多种存储结构

数据元素的机内表示:用二进制位的位串表示数据元素。通常称这种位串为节点。当数据元素有若干个数据项组成是,位串各数据项对应的子位串称为数据域,因此,节点是数据元素的机内表示。

关系的机内表示:数据元素之间的关系的机内表示可以分为顺序映像和非顺序映像。

常用两种存储结构:顺序存储结构和链式存储结构

顺序映像借助于元素在存储器中的相对位置来表示数据元素之间的逻辑关系。

非顺序映像借助于元素存储位置的指针来表示数据元素之间的逻辑关系。

常用数据结构分类:

  数组:把具有相同类型的若干变量按有序的形式组织起来,这些按序排列的同类数据元素的集合称为数组。

  栈:是只能在某一端插入和删除的特殊线性表。按照先进后出的原则存储数据

  队列:   

数据结构 是对计算机内存中的数据的一种安排,它包括数组、链表、栈、二叉树、哈希表等等  

  可以解决的问题:

    现实世界数据存储

    程序员的工具

     建模

  数据结构的特性

数据结构 优点 缺点
数组 插入快,如果知道下表,可以快速的存取 查找慢,删除慢,大小固定
有序数组 比无序的数组查找快 删除和插入慢,大小固定
提供后进先出方式的存取 存取其他项很慢
队列 提供先进先出的凡是的存取 存取其他项很慢
链表 插入快,删除快 查找慢
二叉树 查找、插入、删除都快 删除算法复杂
红-黑树

查找、插入、删除都快,树总是平衡的

算法复杂
2-3-4树

查找、插入、删除都快,树总是平衡的,类似的树对磁盘存储有用

算法复杂
哈希表

如果关键字一致,则存取极快,插入快

删除慢,如果不知道关键字则存取很慢,对存储空间使用不充分

插入、删除快,对最大数据项的存取很快

对其他数据项存取慢

对现实世界建模

有些算法慢且复杂

除了数组之外都可以被认为是抽象数据结构(ADT)

继承与多态

  继承是指由基类扩展或派生形成一个新类。 继承又称子类化。

  多态:指的是以相同的办法处理来自不同类的对象。

基本变量类型

boolean占 一位

    byte一个字节

     char、short二个字节

int、float 4个字节

long、dubbo8个字节

小结:

  数据结构是指数据在计算机内存空间中或磁盘中的组织形式。

  正确选择数据结构会使程序的效率大大提高

  数据结构的例子有数组、栈和链表

  算法是完成特定任务的过程

  在java中,算法经常通过类的方法实现

  本书中介绍的大部分数据结构和算法经常被用来建造数据库

  一些数据结构可以模拟现实世界的情况,例如城市之间的电话线网

  数据库是指由许多类似记录组成的数据存储的集合

  一条记录经常表示现实世界中的一个事物,例如一个雇员或一个汽车零件。

  一条记录被分成字段,每个字段都存储了由这个记录所描述事物的一条特性。

  一个关键字是一条记录中的一个字段,通过它可以对数据执行许多操作。

1对许多数据结构来说,可以(插入)一条记录,可以(查找)它,还可以(删除)它

2按照某种顺序对一个数据结构的内容进行重新排列被称为(排序)

3在数据库中一个字段是一条记录的一部分

4当查找一个特定记录时,所使用的那个字段被称为搜索关键字

5在面向对象程序设计中,一个对象可能包含有数据和方法

6一个类是许多对象的蓝图

8当一个对象想做一些事情时,它使用一个方法

9在java中,访问一个类的方法要用(点)操作符

10在java中,boolean和byte是数据类型

  

java版数据结构与算法 (1综述)的更多相关文章

  1. java版数据结构与算法第二章数组

    数组由一组具有相同类型的数据元素组成,并存储在一组连续存储单元中.一维数组是常量. 二维数组:若一维数组中的数据元素又是一堆数据结构,我们称之为二维数组.二维数组可以看成是n个列向量组成的线性表. 数 ...

  2. JavaScript 版数据结构与算法(二)队列

    今天,我们要讲的是数据结构与算法中的队列. 队列简介 队列是什么?队列是一种先进先出(FIFO)的数据结构.队列有什么用呢?队列通常用来描述算法或生活中的一些先进先出的场景,比如: 在图的广度优先遍历 ...

  3. Android版数据结构与算法(七):赫夫曼树

    版权声明:本文出自汪磊的博客,未经作者允许禁止转载. 近期忙着新版本的开发,此外正在回顾C语言,大部分时间没放在数据结构与算法的整理上,所以更新有点慢了,不过既然写了就肯定尽力将这部分完全整理好分享出 ...

  4. java之数据结构与算法

    1.了解基本数据结构及特点 如,有哪些二叉树,各有什么特点 树二叉搜索树 每个节点都包含一个值,每个节点至多有两棵子树,左孩子小于自己,右孩子大于自己,时间复杂度是O(log(n)),随着不断插入节点 ...

  5. JavaScript 版数据结构与算法(一)栈

    今天,我们要讲的是数据结构与算法中的栈. 栈的简介 栈是什么?栈是一个后进先出(LIFO)的数据结构.栈有啥作用?栈可以模拟算法或生活中的一些后进先出的场景,比如: 十进制转二进制,你需要将余数倒序输 ...

  6. JavaScript 版数据结构与算法(三)链表

    今天,我们要讲的是数据结构与算法中的链表. 链表简介 链表是什么?链表是一种动态的数据结构,这意味着我们可以任意增删元素,它会按需扩容.为何要使用链表?下面列举一些链表的用途: 因为数组的存储有缺陷: ...

  7. JavaScript 版数据结构与算法(四)集合

    今天,我们要讲的是数据结构与算法中的集合. 集合简介 什么是集合?与栈.队列.链表这些顺序数据结构不同,集合是一种无序且唯一的数据结构.集合有什么用?在 Python 中,我经常使用集合来给数组去重: ...

  8. Android版数据结构与算法(一):基础简介

    版权声明:本文出自汪磊的博客,未经作者允许禁止转载. 一.前言 项目进入收尾阶段,忙忙碌碌将近一个多月吧,还好,不算太难,就是麻烦点. 数据结构与算法这个系列早就想写了,一是梳理总结,顺便逼迫自己把一 ...

  9. 数据结构Java版之交换算法(一)

    交换的本质是拷贝,其中拷贝包括两种方式.值拷贝和指针拷贝,在java中没有指针,为此,我们可以理解为地址拷贝,在我看来,指针就是地址. 1.传值方式示例: 由上述示例可得,传值,不能起到交换的作用,原 ...

随机推荐

  1. postgis 随笔

    一.表的定义:    对于任何一种关系型数据库而言,表都是数据存储的最核心.最基础的对象单元.现在就让我们从这里起步吧.    1. 创建表:    CREATE TABLE products (   ...

  2. mac系统 安装pip,用python读写excel(xlrd、xlwt)安装

    1: 先安装python, 下载地址:https://www.python.org/downloads/release/python-372/ 2: 安装pip 下载一个get-pip.py的文件  ...

  3. 图融合之加载子图:Tensorflow.contrib.slim与tf.train.Saver之坑

    import tensorflow as tf import tensorflow.contrib.slim as slim import rawpy import numpy as np impor ...

  4. Git常用命令及使用,GitLab/GitHub初探,Git/Svn区别

    Git安装配置及常用命令 0 Git本地分支管理 1 Git远程分支管理 2 Git Tag标签管理 3 Git Log日志 4 其它高级命令 5 常规使用及介绍 6 角色权限 7 分支定义 8 一般 ...

  5. 关于Javascript中页面动态钟表的简单实现

    1.问题并不繁琐,在于HTML中 DOM(文档对象模型)方法的掌握,我的钟表实现重点用到了三个函数和一个事件 A)setInterval() 方法可按照指定的周期(以毫秒计)来调用函数或计算表达式.s ...

  6. 苹果手机的SB系列(1)听不懂人话的sir

    写在前面,因手买错了(至于怎么买错了不解释)手机才买了一个苹果,价格不扉,但实在让人很不爽.记下了SB的点点. Sir听不懂人话,我让他查非洲安哥拉的时间,却屡次返回美国安哥拉洲的时间,很自恋.

  7. WMI设置有线网卡IP地址

    一.通过WMI获取物理适配器序号 NetEnabled: 是否启用了适配器,True为启用,False为禁用;PhysicalAdapter: 适配器是否物理或逻辑适配器,True为物理,False为 ...

  8. 常用adb 指令

    adb指令 monkey https://www.cnblogs.com/aland-1415/p/6949964.html

  9. Python_Mix*re模块基础方法,进阶,正则表达式的使用

    re模块import re 基础方法 findall:匹配所有 ,每一项都是列表中的一个元素,返回的是列表 search只匹配从左到右的第一个,得到的不是直接的结果,而是一个变量,通过这个变量的gro ...

  10. Dynamic learning rate in training - 培训中的动态学习率

    I'm using keras 2.1.* and want to change the learning rate during training. I know about the schedul ...