数据结构的基本操作

对于任何数据结构,基本操作就是 遍历+访问(增删改查)

各种数据结构的遍历和访问两种形式:线性的和非线性的

一、线性形式

以 for/while 迭代为代表

数组遍历框架,是典型的线性迭代结构

cpp 复制代码
void traverse(int[] arr){
    for (int i =0;i<arr.length;i++){
            //迭代访问 arr[i]
    }
}

链表遍历框架,兼具迭代和递归结构

迭代结构:

cpp 复制代码
/* 基本的单链表节点 */
class ListNode {
    int val;
    ListNode next;
}

void traverse(ListNode head) {
    for (ListNode p = head; p != null;p = p.next) {
        //迭代访问p.val
    }
}

二、非线性形式

链表遍历框架,递归结构:

cpp 复制代码
/* 基本的单链表节点 */
class ListNode {
    int val;
    ListNode next;
}

void traverse(ListNode head) {
    // 递归访问 head.val
    traverse(ListNode head.next)  // 访问链表中的下一个节点
}

二叉树遍历框架,是典型的非线性递归遍历结构

二叉树的结构定义:

cpp 复制代码
/* 基本的二叉树节点 */
class TreeNode {
    int val;
    TreeNode left,right;
}

二叉树的递归遍历:

cpp 复制代码
void traverse (TreeNode root){
    traverse(root.left);
    traverse(root.right);
}

N叉树的遍历:

cpp 复制代码
/* 基本的N叉树节点 */
class ListNode {
    int val;
    TreeNode[] children;
}

void traverse(TreeNode root) {
    for (TreeNode child : root.childern)
        traverse(child);
}

​
相关推荐
yuannl1032 分钟前
数据结构----双端队列实现
数据结构
无限进步_1 小时前
【C++】只出现一次的数字 II:位运算的三种解法深度解析
数据结构·c++·ide·windows·git·算法·leetcode
qq_454245031 小时前
通用引用管理框架
数据结构·架构·c#
lcj25112 小时前
【C语言】数据在内存中的存储
c语言·数据结构
旖-旎2 小时前
哈希表(字母异位次分组)(5)
数据结构·c++·算法·leetcode·哈希算法·散列表
paeamecium4 小时前
【PAT甲级真题】- All Roads Lead to Rome (30)
数据结构·c++·算法·pat考试·pat
PD我是你的真爱粉4 小时前
Redis 数据类型与底层实现:从 SDS、Quicklist 到 ZSet 跳表彻底讲透
数据结构·redis
汀、人工智能4 小时前
[特殊字符] 第100课:任务调度器
数据结构·算法·数据库架构·贪心··任务调度器
会编程的土豆5 小时前
日常做题 vlog
数据结构·c++·算法
旖-旎6 小时前
哈希表(存在重复元素||)(4)
数据结构·c++·算法·leetcode·哈希算法·散列表