news 2026/4/15 6:50:52

数据结构与算法笔记:树、链表、排序与队列实现

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
数据结构与算法笔记:树、链表、排序与队列实现

数据结构与算法笔记:树、链表、排序与队列实现

目录

  • 数据结构与算法笔记:树、链表、排序与队列实现
    • 🌲 二叉树(Binary Tree)
      • TreeNode 类定义
      • 二叉树前序遍历(递归)
      • 二叉树搜索(查找目标值节点)
    • 🔗 单链表(Linked List)
      • ListNode 节点类
      • LinkedList 类实现
    • 🔄 队列(Queue) - 链式实现
      • QueueNode 节点类
      • LinkedQueue 类实现
    • 11111栈(Stack) - 数组实现1111
      • ArrayStack 类实现(补充完整版)
    • 📊 排序算法总结
    • 🔁 排序算法实现
      • 选择排序(Selection Sort)
      • 归并排序(Merge Sort)
    • ✅ 总结

本文基于手写笔记整理,涵盖二叉树遍历、搜索、链表、栈、队列以及常见排序算法的Java实现。适合初学者快速掌握核心数据结构和算法逻辑。


🌲 二叉树(Binary Tree)

TreeNode 类定义

classTreeNode{intval;TreeNodeleft;TreeNoderight;publicTreeNode(intval){this.val=val;}}

二叉树前序遍历(递归)

publicstaticvoidorder(TreeNodenode){if(node==null)return;order(node.left);System.out.print(node.val+" ");order(node.right);}

⚠️ 注意:此处为中序遍历,代码顺序应为left -> root -> right。若需前序则应为root -> left -> right

二叉树搜索(查找目标值节点)

publicstaticTreeNodesearch(TreeNodenode,inttarget){if(node==null)returnnull;if(node.val==target)returnnode;TreeNodeleft=search(node.left,target);if(left!=null)returnleft;returnsearch(node.right,target);}

🔗 单链表(Linked List)

ListNode 节点类

classListNode{intval;ListNodenext;publicListNode(intval){this.val=val;}}

LinkedList 类实现

publicclassLinkedList{privateListNodehead;publicvoidaddFirst(intval){ListNodenewNode=newListNode(val);newNode.next=head;head=newNode;}publicvoidprint(){ListNodecur=head;while(cur!=null){System.out.print(cur.val+" ");cur=cur.next;}System.out.println();}}

🔄 队列(Queue) - 链式实现

QueueNode 节点类

classQueueNode{intval;QueueNodenext;publicQueueNode(intval){this.val=val;this.next=null;}}

LinkedQueue 类实现

publicclassLinkedQueue{privateQueueNodefront;privateQueueNoderear;publicLinkedQueue(){this.front=null;this.rear=null;}publicbooleanisEmpty(){returnfront==null;}publicvoidenqueue(intval){QueueNodenewNode=newQueueNode(val);if(isEmpty()){front=rear=newNode;}else{rear.next=newNode;rear=newNode;}}publicintdequeue(){if(isEmpty()){System.out.println("队列空");return-1;}intval=front.val;front=front.next;if(front==null){rear=null;}returnval;}}

11111栈(Stack) - 数组实现1111

ArrayStack 类实现(补充完整版)

publicclassArrayStack{privateint[]data;privateinttop;privateintcapacity;publicArrayStack(intsize){this.capacity=size;this.data=newint[capacity];this.top=-1;}publicbooleanisEmpty(){returntop==-1;}publicvoidpush(intval){if(top>=capacity-1){System.out.println("栈满");return;}data[++top]=val;}publicintpop(){if(isEmpty()){System.out.println("栈空");return-1;}returndata[top--];}publicintpeek(){if(isEmpty()){System.out.println("栈空");return-1;}returndata[top];}}

📊 排序算法总结

算法时间复杂度空间复杂度特点
快排O(n log n)O(log n)原地排序,不稳定
直接插入O(n²)O(1)稳定,小规模高效
选择排序O(n²)O(1)不稳定,交换次数少
归并排序O(n log n)O(n)稳定,适合链表
冒泡排序O(n²)O(1)稳定,效率低

💡 补充说明:

  • n个结点的完全二叉树:有n+1个空指针域
  • 第k层最多:2^(k-1) 个结点
  • 叶子结点数:≤ 总结点数 / 2
  • 度为2的结点数= 叶子结点数 - 1
  • 满二叉树:所有层都填满
  • 完全二叉树:除最后一层外,其余层全满

🔁 排序算法实现

选择排序(Selection Sort)

publicvoidselectionSort(int[]arr){for(inti=0;i<arr.length-1;i++){intminIndex=i;for(intj=i+1;j<arr.length;j++){if(arr[j]<arr[minIndex]){minIndex=j;}}swap(arr,i,minIndex);}}privatevoidswap(int[]arr,inti,intj){inttemp=arr[i];arr[i]=arr[j];arr[j]=temp;}

归并排序(Merge Sort)

publicvoidmergeSort(int[]arr,intleft,intright){if(left>=right)return;intmid=(left+right)/2;mergeSort(arr,left,mid);mergeSort(arr,mid+1,right);merge(arr,left,mid,right);}privatevoidmerge(int[]arr,intl,intm,intr){int[]temp=newint[r-l+1];inti=l,j=m+1,k=0;while(i<=m&&j<=r){temp[k++]=arr[i]<=arr[j]?arr[i++]:arr[j++];}while(i<=m)temp[k++]=arr[i++];while(j<=r)temp[k++]=arr[j++];System.arraycopy(temp,0,arr,l,temp.length);}

✅ 总结

本笔记系统梳理了以下内容:

  1. 二叉树基本操作:遍历与搜索
  2. 单链表:增删查打印
  3. 队列与栈:链式与数组实现
  4. 经典排序算法:选择、归并
  5. 复杂度分析:时间与空间对比

📝 建议结合代码调试运行,加深对递归、指针、内存管理的理解。


📌学习建议

  • 手写代码 → 理解逻辑 → 调试验证 → 优化改进
  • 掌握基础后可拓展:BST、AVL、堆、哈希表等

👉 欢迎关注我,持续分享算法与数据结构干货!


本文由手写笔记整理而成,欢迎点赞收藏,一起进步!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/12 18:51:54

Open-AutoGLM与JMeter集成实践(性能测试新范式)

第一章&#xff1a;Open-AutoGLM与JMeter集成的背景与意义随着人工智能技术在自动化测试领域的深入应用&#xff0c;传统性能测试工具面临智能化升级的需求。JMeter作为广泛使用的开源性能测试工具&#xff0c;擅长模拟高并发请求和监控系统响应&#xff0c;但在测试用例生成、…

作者头像 李华
网站建设 2026/4/12 21:59:00

Open-AutoGLM vs BrowserStack:3个关键场景实测,谁才是兼容性王者?

第一章&#xff1a;Open-AutoGLM vs BrowserStack&#xff1a;兼容性测试的背景与意义在现代Web应用开发中&#xff0c;确保应用程序在不同设备、操作系统和浏览器环境中的稳定运行至关重要。兼容性测试作为质量保障的关键环节&#xff0c;直接影响用户体验与产品可靠性。随着前…

作者头像 李华