Jorgen's blog Jorgen's blog
首页
  • 平台架构
  • 混合式开发记录
  • 推送服务
  • 数据分析
  • 实时调度
  • 架构思想

    • 分布式
  • 编程框架工具

    • 编程语言
    • 框架
    • 开发工具
  • 数据存储与处理

    • 数据库
    • 大数据
  • 消息、缓存与搜索

    • 消息队列
    • 搜索与日志分析
  • 前端与跨端开发

    • 前端技术
    • Android
  • 系统与运维

    • 操作系统
    • 容器化与 DevOps
  • 物联网与安全

    • 通信协议
    • 安全
    • 云平台
newland
  • 关于我
  • 终身学习
  • 关于时间的感悟
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

jorgen

Love it, make mistakes, learn, keep grinding.
首页
  • 平台架构
  • 混合式开发记录
  • 推送服务
  • 数据分析
  • 实时调度
  • 架构思想

    • 分布式
  • 编程框架工具

    • 编程语言
    • 框架
    • 开发工具
  • 数据存储与处理

    • 数据库
    • 大数据
  • 消息、缓存与搜索

    • 消息队列
    • 搜索与日志分析
  • 前端与跨端开发

    • 前端技术
    • Android
  • 系统与运维

    • 操作系统
    • 容器化与 DevOps
  • 物联网与安全

    • 通信协议
    • 安全
    • 云平台
newland
  • 关于我
  • 终身学习
  • 关于时间的感悟
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • Go学习指南
  • Golang入门
  • DS&A
    • stack
    • Queue
      • PriorityQueue
      • Linked List
      • Array
  • 算法碎碎念
  • 编程语言范式:理解编程的思维模式
  • 并发编程模型 - 现代软件开发的核心能力
  • 并发编程模型-跨越语言的并行艺术
  • 类型系统-编程语言的骨架与灵魂
  • 类型系统探秘:编程语言的灵魂架构
  • 类型系统探秘:编程语言的骨架与灵魂
  • 编程语言的内存管理与垃圾回收机制
  • 编程语言类型系统-类型背后的哲学
  • 编程语言设计原理 - 构建高效表达的工具
  • 编程语言设计原理与实现 - 从想法到代码的艺术
  • 编程语言设计原理与实现 - 构建你自己的语言
  • 编程语言选择指南:找到最适合你的技术栈
  • 静态类型与动态类型:编程语言的两条路
  • 编程语言解释器与编译器原理-从源码到执行的旅程
  • 函数式编程范式-编程中的数学思维
  • 编程语言的测试与调试技术-构建可靠软件的基石
  • 编程语言的语法设计与解析技术-构建优雅表达的艺术
  • 元编程与反射机制-编程语言的自我审视与重塑艺术
  • 编程语言学习方法与认知过程-掌握多语言思维的钥匙
  • 编程语言的互操作性-跨越语言边界的无缝协作
  • 编程语言的错误处理机制-从异常到错误码的哲学思考
  • 编程语言的性能优化技术-从代码到执行的效率革命
  • 渐进式类型系统-静态与动态的完美融合
  • 编程语言的包管理与依赖系统-构建现代软件开发的基石
  • 编程语言的演化历史与未来趋势-从机器码到AI时代的语言革命
  • 编程语言的异步编程模型-现代应用开发的加速器
  • programming_languages
Jorgen
2023-12-26
目录

DS&A

# stack

FILO

push peek/ pop

uses of stacks

  1. unde/redo features in text editors
  2. moving back/forward though brower history
  3. backtracking algorithms(maze file directories)
  4. calling functions(call stack)

# Queue

FIFO

add enqueue offer / remove dequeue poll

  1. keyboard buffer(letters should appear on the screen in the order they’re pressed)
  2. printer queue (print jobs should be completed in order)
  3. used in LinkedLists, priorityQueues, Breath-first search

# PriorityQueue

a FIFO data structure that serves element with the highest priorities first before elements with lower priority

# Linked List

  • Single linked list
  • doule linked list

Advantage

  • Dynamic data structure (allocates needed memory while running)
  • Insertion and deletion of nodes is easyO(1)
  • NO/Low memory Waste

Disadvantage

  • Greater memory usage(additional pointer)
  • No random access of elements (no index [i])
  • Accessing searching elements is more time consuming O(n)

uses

  • implements stack/queue

  • GPS navigation

  • music playlist

# Array

static / dynamic

Advantage

  • random access of elements O(1)
  • Good locality of reference and data cache utilization
  • Easy to insert/delete at the end

Disadvantage

  • wastes more memory
  • shifting elements is time consuming O(n)
  • Expanding/Shrinking the array is time consumingO(n)
上次更新: 2026/01/28, 13:30:02
Golang入门
算法碎碎念

← Golang入门 算法碎碎念→

最近更新
01
LLM
01-30
02
intro
01-30
03
intro
01-30
更多文章>
Theme by Vdoing | Copyright © 2019-2026 Jorgen | MIT License
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式