全面掌握数据结构: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) s[i]
删除 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算法

相关推荐
cpp_250115 小时前
P1024 [NOIP 2001 提高组] 一元三次方程求解
数据结构·c++·算法·题解·二分答案·洛谷·csp
半瓶榴莲奶^_^16 小时前
jvm java虚拟机
java·jvm
Gofarlic_oms120 小时前
利用API实现ANSYS许可证管理自动化集成
运维·服务器·开发语言·matlab·自动化·负载均衡
AI+程序员在路上21 小时前
VS Code 完全使用指南:下载、安装、核心功能与 内置AI 编程助手实战
开发语言·人工智能·windows·开源
invicinble1 天前
这里对java的知识体系做一个全域的介绍
java·开发语言·python
catchadmin1 天前
使用 PHP TrueAsync 改造 Laravel 协程异步化的可行路径
开发语言·php·laravel
wbs_scy1 天前
【Linux 线程进阶】进程 vs 线程资源划分 + 线程控制全详解
java·开发语言
ss2731 天前
食谱推荐系统功能测试如何写?
java·数据库·spring boot·功能测试
AI人工智能+电脑小能手1 天前
【大白话说Java面试题】【Java基础篇】第15题:JDK1.7中HashMap扩容为什么会发生死循环?如何解决
java·开发语言·数据结构·后端·面试·哈希算法
try2find1 天前
打印ascii码报错问题
java·linux·前端