语言小结
  • program-language-note
  • contact
  • common
    • 代码风格
    • 概念语法
      • 类型
      • 注释
      • 字符
      • 语句
      • 操作符
      • 函数
        • 递归
    • 格式化参数
    • 源码结构
    • 数据结构
    • 名词
  • 电路
    • 内存地址
    • Untitled
    • Code
  • C
    • note
    • overview
      • helloworld.c
      • c标准
      • 关键字
      • tips
      • util.c
    • 语法
      • 函数
        • main
      • const
      • static
      • 作用域
    • 编译和运行
      • c代码内存模型
      • 预处理
        • include
        • define
    • 头文件
    • 基本数据类型
      • 整型
      • 枚举
      • 浮点型
      • 指针
      • 数组
      • 结构和联合
    • 指针&数组、指针&函数
    • API
    • 存储结构
    • 操作符
      • sizeof
    • typedef
    • 输入输出
    • 格式化参数
    • 左値右値
    • 性能思考
    • volatile
    • 字符串
      • find_char.c
    • 动态分配
      • alloc.h
      • alloc.c
      • alloc_usage.c
    • note
  • cpp
    • 资源
    • note
    • 数据结构
    • 智能指针
    • 编译过程
  • shell
    • usage
    • Untitled
  • Rust
    • overview
  • Lisp
    • Untitled
  • web
    • overview
      • index
      • 软件工具
      • ARIA规范
      • SEO
    • style
    • html
      • 标签、元素
        • 标签快记
        • 联系信息
        • 引用
        • 列表
        • 语言设置
        • meta
      • 页面结构
        • 图片
        • 视频
        • 引用css、js文件
      • 等价字符
      • 链接
        • 邮件
      • 表单
        • note
      • 表格
    • css
      • 字体
      • 布局
        • position
        • float
        • display
        • flexbox
    • js
    • note
  • java
    • note
    • java语言程序设计
    • 设计模式
      • 大话设计模式-吴强-2010
      • 大话设计模式-程杰
      • 设计模式-gof
      • 设计模式解析
      • 原则
      • 单例
    • java程序设计第10版-基础
    • java程序设计第10版-进阶
    • java核心技术第9版-I
    • jar包
    • 安全
    • 反射
  • python
    • note
    • index
    • 个人记忆点
    • 疑惑
    • simple
    • 精通Python爬虫框架scrapy
    • 语法
    • scrapy
      • notice
      • index
  • 汇编
    • Untitled
  • kotlin
    • index
    • note
    • by android
      • note
      • index
  • groovy
    • gradle
Powered by GitBook
On this page
  • 链表
  • 堆栈
  • 队列
  • 树

Was this helpful?

  1. common

数据结构

链表

单链表,双向链表

堆栈

操作名称统一是pop, push, top

接口定义:传统是pop的同时返回顶部値,无top;非传统则是pop不返回值,top返回顶部値,push压栈

实现方式:静态数组、动态数组、链表

队列

没有统一的操作名称,一般叫做insert, delete

接口定义:传统是delete的同时返回値

实现方式:静态循环数组(变量,或者让数组一直保有一个不使用的占位値)、动态数组、链表

树

二叉树

每个节点最多拥有两个子节点,

每个节点都比左侧的子节点树上的所有节点都要大;同时比右侧的子节点树上的所有节点都要小

根节点、叶节点

删除

实现二叉树的删除在节点有两个子节点的时候,如果按常规思路会比较麻烦。

此时可以对要删除节点的左子树进行操作,获取其最大子节点,用値替换原来要删除的节点的値,再删除

遍历

前序遍历

先获取节点,然后优先左侧子节点,再右侧子节点

中序、后序、层次遍历

实现

数组形式

节点N的父节点是 (N+1)/2 - 1 ; 左子节点是 2N + 1 ; 右子节点是 2N + 2

Previous源码结构Next名词

Last updated 5 years ago

Was this helpful?