• 【算法与数据结构】--常见数据结构--栈和队列


    一、栈

    栈(Stack) 是一种基本的数据结构,具有后进先出(LIFO)的特性,类似于现实生活中的一叠盘子。栈用于存储一组元素,但只允许在栈顶进行插入(入栈)和删除(出栈)操作。以下是栈的关键特性和操作:

    1.1 栈的特性:
    1. 后进先出(LIFO):最后进栈的元素将首先出栈,类似于将盘子放在一叠盘子的顶部,取盘子时总是从顶部开始。
    2. 只能操作栈顶元素:栈只允许对栈顶元素进行插入和删除操作,其他元素必须等待。
    1.2 栈的基本操作:
    1. 入栈(Push):将元素添加到栈顶。
    2. 出栈(Pop):移除栈顶元素,并返回它。
    3. 查看栈顶元素(Peek):查看栈顶元素的值,但不将其移出栈。
    1.3 代码示例:
    • C# 示例
    using System;
    using System.Collections.Generic;
    
    class Program
    {
        static void Main()
        {
            Stack<int> stack = new Stack<int>();
    
            // 入栈
            stack.Push(1);
            stack.Push(2);
            stack.Push(3);
    
            // 出栈
            int poppedItem = stack.Pop();
            Console.WriteLine("Popped: " + poppedItem); // 输出:Popped: 3
    
            // 查看栈顶元素
            int topItem = stack.Peek();
            Console.WriteLine("Top: " + topItem); // 输出:Top: 2
    
            // 遍历栈
            while (stack.Count > 0)
            {
                int item = stack.Pop();
                Console.WriteLine(item);
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • 30
    • Java 示例
    import java.util.Stack;
    
    public class Main {
        public static void main(String[] args) {
            Stack<Integer> stack = new Stack<>();
    
            // 入栈
            stack.push(1);
            stack.push(2);
            stack.push(3);
    
            // 出栈
            int poppedItem = stack.pop();
            System.out.println("Popped: " + poppedItem); // 输出:Popped: 3
    
            // 查看栈顶元素
            int topItem = stack.peek();
            System.out.println("Top: " + topItem); // 输出:Top: 2
    
            // 遍历栈
            while (!stack.isEmpty()) {
                int item = stack.pop();
                System.out.println(item);
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    这些代码示例演示了如何在C# 和 Java 中使用内置的栈数据结构,执行入栈、出栈、查看栈顶元素以及遍历栈的操作。栈是一种重要的数据结构,在算法和数据处理中有广泛的应用。

    二、队列

    队列(Queue) 是一种基本的数据结构,具有先进先出(FIFO)的特性,类似于现实生活中排队等候的情景。队列用于存储一组元素,并允许在队列的一端插入元素(入队),在另一端删除元素(出队)。以下是队列的关键特性和操作:

    2.1 队列的特性:
    1. 先进先出(FIFO):最早入队的元素将最早出队,类似于排队时最早到达的人会最早被服务。
    2. 只能操作队头和队尾:队列允许在队尾进行入队操作,在队头进行出队操作,其他元素必须等待。
    2.2 队列的基本操作:
    1. 入队(Enqueue):将元素添加到队列的尾部。
    2. 出队(Dequeue):移除队列的头部元素,并返回它。
    3. 查看队头元素(Peek):查看队列头部元素的值,但不将其出队。
    2.3 队列的应用:
    • 队列常用于多种情况,包括任务调度、广度优先搜索、缓冲等需要维护元素的先后顺序的问题。
    2.4 代码示例:
    • C#示例
    using System;
    using System.Collections.Generic;
    
    class Program
    {
        static void Main()
        {
            Queue<int> queue = new Queue<int>();
    
            // 入队
            queue.Enqueue(1);
            queue.Enqueue(2);
            queue.Enqueue(3);
    
            // 出队
            int dequeuedItem = queue.Dequeue();
            Console.WriteLine("Dequeued: " + dequeuedItem); // 输出:Dequeued: 1
    
            // 查看队头元素
            int frontItem = queue.Peek();
            Console.WriteLine("Front: " + frontItem); // 输出:Front: 2
    
            // 遍历队列
            foreach (int item in queue)
            {
                Console.WriteLine(item);
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26
    • 27
    • 28
    • 29
    • Java示例
    import java.util.LinkedList;
    import java.util.Queue;
    
    public class Main {
        public static void main(String[] args) {
            Queue<Integer> queue = new LinkedList<>();
    
            // 入队
            queue.offer(1);
            queue.offer(2);
            queue.offer(3);
    
            // 出队
            int dequeuedItem = queue.poll();
            System.out.println("Dequeued: " + dequeuedItem); // 输出:Dequeued: 1
    
            // 查看队头元素
            int frontItem = queue.peek();
            System.out.println("Front: " + frontItem); // 输出:Front: 2
    
            // 遍历队列
            for (int item : queue) {
                System.out.println(item);
            }
        }
    }
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 24
    • 25
    • 26

    这些代码示例演示了如何在C# 和 Java 中使用内置的队列数据结构,执行入队、出队、查看队头元素以及遍历队列的操作。队列是一种重要的数据结构,在许多情况下用于维护元素的顺序,特别是在多线程和并发编程中,队列非常有用。

    三、应用场景

    队列和栈是两种常见的数据结构,它们在不同应用场景中发挥着重要的作用:

    3.1 队列的应用场景:
    1. 任务调度:队列常用于多任务调度,确保任务按照特定顺序执行。例如,操作系统中的进程调度,打印队列中的文档,或者异步任务队列。
    2. 广度优先搜索(BFS):在图算法中,BFS 使用队列来实现,以探索图中的节点。这在寻找最短路径、社交网络分析和推荐系统等应用中非常有用。
    3. 缓冲:队列用于缓冲数据,以平衡生产者和消费者之间的速度差异。消息队列(如RabbitMQ和Kafka)用于解耦组件,处理大量数据。
    4. 线程调度:多线程应用中,线程池通常使用队列来存储待处理的任务。新任务入队,空闲线程出队执行任务,确保任务按照先来先服务的原则执行。
    5. Web请求管理:Web服务器通常使用队列来管理接收到的请求,以便逐个处理它们,避免过载和提供更好的性能。
    3.2 栈的应用场景:
    1. 函数调用:编程中,函数调用栈用于跟踪函数的嵌套调用。每个函数调用都将当前状态压入栈,返回后再从栈中弹出。
    2. 逆波兰表达式和计算器:栈用于解析和计算逆波兰表达式,它允许处理操作符的优先级和括号。
    3. 撤销功能:许多应用程序(如文本编辑器、图像编辑器)使用栈来记录用户的操作历史,以便提供撤销和重做功能。
    4. 括号匹配:栈用于检查表达式中的括号是否匹配,例如在编译器中检查代码的语法。
    5. 浏览器历史记录:浏览器中的“后退”和“前进”按钮通常使用栈来维护访问过的页面历史记录。
    6. 深度优先搜索(DFS):在图算法中,DFS 通常使用递归和栈来实现,以探索图的节点。

    这些是队列和栈的一些主要应用场景。它们在许多领域都具有重要作用,帮助解决了各种问题,从任务调度到数据结构的操作和搜索算法。根据具体的问题需求,选择正确的数据结构可以极大地提高算法和应用的效率。

    四、总结

    栈(Stack)是一种基本的数据结构,具有后进先出(LIFO)的特性,类似于现实生活中的一叠盘子。栈用于存储一组元素,但只允许在栈顶进行插入(入栈)和删除(出栈)操作。栈的主要特性包括后进先出(LIFO)和只能操作栈顶元素。栈的基本操作包括入栈(Push)、出栈(Pop)、和查看栈顶元素(Peek)。
    队列(Queue)是一种基本的数据结构,具有先进先出(FIFO)的特性,类似于现实生活中排队等候的情景。队列用于存储一组元素,允许在队列的一端插入元素(入队)和在另一端删除元素(出队)。队列的主要特性包括先进先出(FIFO)和只能操作队头和队尾元素。队列的基本操作包括入队(Enqueue)、出队(Dequeue)、和查看队头元素(Peek)。
    栈常用于需要按照相反顺序处理数据的场景,如函数调用、逆波兰表达式求值和历史记录的撤销功能。队列通常用于需要维护元素的先后顺序,如任务调度、广度优先搜索和数据缓冲。

  • 相关阅读:
    浅谈小程序开源业务架构建设之路
    你真的了解 RSA 加密算法吗?
    【和小白一起练习CTF】攻防世界:web基础练习题(1)
    HTTP协议版本检测
    基于虚拟同步发电机控制的双机并联Simulink仿真模型
    数据结构与算法复习:第六弹
    Android--Retrofit2执行多个请求任务并行,任务结束后执行统一输出结果
    千亿贴息助科研,维视智造院校实验室建设攻略来了(四)!
    程序员们,我们能工作到65岁吗?
    火山引擎DataLeap的数据血缘用例与设计概述
  • 原文地址:https://blog.csdn.net/gangzhucoll/article/details/133820104