全面掌握数据结构:Java 与 Go 定义方式 + 原理 + 使用场景

在算法竞赛(如蓝桥杯)、后端开发(如博客系统)、以及面试中,数据结构都是最核心的基础能力。

这篇文章不是简单罗列代码,而是帮你建立一个体系化认知

  • 每种数据结构怎么定义(Java / Go)

  • 底层原理

  • 时间复杂度

  • 实战中怎么用(非常关键)


一、数组(Array)

Java

复制代码
int[] arr = new int[10];
int[] arr2 = {1, 2, 3};
int[][] matrix = new int[3][4];

Go

复制代码
var arr [10]int
arr2 := [3]int{1, 2, 3}
var matrix [3][4]int

📌 特点

  • 固定长度

  • 连续内存

  • 支持随机访问

⏱️ 复杂度

  • 访问:O(1)

  • 插入/删除:O(n)


二、动态数组(Java ArrayList vs Go Slice)

Java:ArrayList

复制代码
import java.util.*;

List<Integer> list = new ArrayList<>();

list.add(1);
list.get(0);
list.set(0, 100);
list.remove(0);
int size = list.size();

Go:Slice

复制代码
s := make([]int, 0, 10)

s = append(s, 1)
x := s[0]
s[0] = 100

// 删除
i := 0
s = append(s[:i], s[i+1:]...)

len(s)
cap(s)

📌 核心理解(非常重要)

对比 Java ArrayList Go Slice
本质 封装数组 数组引用
扩容 1.5倍 约2倍
访问 list.get(i) si
删除 remove append拼接

⚠️ 常见坑(Go)

复制代码
func modify(s []int) {
    s[0] = 999
}

👉 会影响原数组(引用语义)


三、链表(Linked List)

Java

复制代码
class ListNode {
    int val;
    ListNode next;
    ListNode(int val) { this.val = val; }
}

Go

复制代码
type ListNode struct {
    Val  int
    Next *ListNode
}

📌 特点

  • 非连续内存

  • 插入删除快

  • 查找慢

⏱️ 复杂度

  • 插入:O(1)

  • 查找:O(n)


四、栈(Stack)

Java(推荐)

复制代码
Deque<Integer> stack = new ArrayDeque<>();
stack.push(1);
stack.pop();

Go

复制代码
type Stack []int

func (s *Stack) Push(x int) {
    *s = append(*s, x)
}

func (s *Stack) Pop() int {
    n := len(*s)
    val := (*s)[n-1]
    *s = (*s)[:n-1]
    return val
}

📌 使用场景

  • 括号匹配

  • 表达式计算

  • DFS


五、队列(Queue)

Java

复制代码
Queue<Integer> q = new LinkedList<>();
q.offer(1);
q.poll();

Go

复制代码
type Queue []int

func (q *Queue) Push(x int) {
    *q = append(*q, x)
}

func (q *Queue) Pop() int {
    val := (*q)[0]
    *q = (*q)[1:]
    return val
}

📌 使用场景

  • BFS

  • 任务队列

  • 消息队列思想


六、双端队列(Deque)

Java

复制代码
Deque<Integer> deque = new ArrayDeque<>();
deque.addFirst(1);
deque.addLast(2);

Go

复制代码
type Deque []int

func (d *Deque) PushFront(x int) {
    *d = append([]int{x}, *d...)
}

func (d *Deque) PushBack(x int) {
    *d = append(*d, x)
}

七、哈希表(Map)

Java

复制代码
HashMap<String, Integer> map = new HashMap<>();
map.put("a", 1);

Go

复制代码
m := make(map[string]int)
m["a"] = 1

📌 特点

  • 快速查找

  • 无序

⏱️ 复杂度

  • 平均 O(1)

八、集合(Set)

Java

复制代码
HashSet<Integer> set = new HashSet<>();
set.add(1);

Go

复制代码
set := make(map[int]struct{})
set[1] = struct{}{}

九、二叉树(Binary Tree)

Java

复制代码
class TreeNode {
    int val;
    TreeNode left, right;
}

Go

复制代码
type TreeNode struct {
    Val int
    Left, Right *TreeNode
}

📌 使用场景

  • 搜索

  • 排序

  • 表达式树


十、堆(Heap / 优先队列)

Java

复制代码
PriorityQueue<Integer> pq = new PriorityQueue<>();

Go

复制代码
import "container/heap"

// 需要实现接口(略)

📌 使用场景

  • TopK问题

  • 调度系统

  • 优先级任务


十一、图(Graph)

Java

复制代码
List<List<Integer>> graph = new ArrayList<>();

Go

复制代码
graph := make([][]int, n)

📌 使用场景

  • 路径问题

  • 社交关系

  • 推荐系统


十二、并查集(Union Find)

Java

复制代码
class UnionFind {
    int[] parent;
}

Go

复制代码
type UnionFind struct {
    parent []int
}

📌 使用场景

  • 连通性问题

  • Kruskal算法

相关推荐
NE_STOP7 小时前
Docker--Docker Swarm集群
java
2301_773643627 小时前
ceph池
开发语言·ceph·python
两年半的个人练习生^_^7 小时前
JMM 进阶:彻底理解 CAS 实现原理
java·开发语言
wuminyu7 小时前
Java锁机制之park和unpark源码剖析
java·linux·c语言·jvm·c++
半个烧饼不加肉7 小时前
JS 底层探究-- 事件循环
开发语言·前端·javascript
W_LuYi1857 小时前
手撸极简zkEVM验证器:RISC-V电路实践
java·risc-v
asdfg12589637 小时前
C 语言中产生伪随机数的标准做法
c语言·开发语言
AI人工智能+电脑小能手7 小时前
【大白话说Java面试题 第102题】【并发篇】第2题:volatile 能否保证线程安全?
java·安全·面试
KobeSacre7 小时前
JUC 概述
java·开发语言
小bo波8 小时前
形式化方法 × UML
java·软件工程·uml·面向对象·形式化方法·tla+