数据结构(二)栈和队列

news2025/1/12 20:59:19

本文是在原本数据结构与算法闯关的基础上总结得来,加入了自己的理解和部分习题讲解

原活动链接

邀请码: JL57F5

目录

  • 栈和队列
    • 1.什么是栈 ?
      • 栈的入栈、出栈操作
    • 2.什么是队列 ?
      • 队列的入队和出队
    • 3.案例讲解 : 使用Python实现栈来管理定时任务
      • `Task` 类
      • `TaskStack` 类
    • 4.案例讲解 : 如何用“栈”来处理浏览器的历史记录?
    • 5.闯关题

栈和队列

1.什么是栈 ?

栈也是一种数据呈线性排列的数据结构,不过在这种结构中,我们只能访问最新添加的数据。栈就像是一摞书,拿到新书时我们会把它放在书堆的最上面,取书时也只能从最上面的新书开始取。

Image Name

栈的入栈、出栈操作

往栈中添加数据的操作叫作"入栈"(push)。

Image Name

从栈中取出数据的操作叫作"出栈"( pop )

Image Name

像栈这种最后添加的数据最先被取出,即“后进先出”的结构,我们称为Last In First Out,简称LIFO。与链表和数组一样,栈的数据也是线性排列,但在栈中,添加和删除数据的操作只能在一端进行,访问数据也只能访问到顶端的数据。想要访问中间的数据时,就必须通过出栈操作将目标数据移到栈顶才行。大家要注意这一点

栈只能在一端操作这一点看起来似乎十分不便,但在只需要访问最新数据时,使用它就比较方便了

2.什么是队列 ?

与前面提到的数据结构相同,队列中的数据也呈线性排列。虽然与栈有些相似,但队列中添加和删除数据的操作分别是在两端进行的。就和“队列”这个名字一样,把它想象成排成一队的人更容易理解。在队列中,处理总是从第一名开始往后进行,而新来的人只能排在队尾。

Image Name

队列的入队和出队

往队列中添加数据的操作叫作"入队"

Image Name

从队列中删除数据的操作叫作"出队"

Image Name

像队列这种最先进去的数据最先被取来,即“先进先出”的结构,我们称为First In First Out,简称FIFO

与栈类似,队列中可以操作数据的位置也有一定的限制。在栈中,数据的添加和删除都在同一端进行,而在队列中则分别是在两端进行的。队列也不能直接访问位于中间的数据,必须通过出队操作将目标数据变成首位后才能访问。“先来的数据先处理”是一种很常见的思路,所以队列的应用范围非常广泛.

3.案例讲解 : 使用Python实现栈来管理定时任务

定时任务在公司业务中经常会出现,其应用涉及到定时各种自动化操作,如备份操作、数据清理、报告生成等

定时任务的一个重要用途是实现自动化操作。自动化操作可以提高开发、测试和运维等人员的效率,减少人为错误及其所带来的负面影响。 我们可以通过定时任务来自动执行系统备份、日志清理、文件同步和数据导出等操作

再比如 , 在机器学习任务中,训练时间可能非常长,而且计算量也非常大,可以通过定时任务来自动执行分布式训练操作,以节省时间和费用。另外,在大规模数据分析中,我们可以使用定时任务来分批导入数据、计算指标等,以提高数据分析的处理效率和准确性

import time

class Task:
    def __init__(self, name, timeout, interval=None):
        self.name = name  # 任务名称
        self.timeout = timeout  # 任务执行时间
        self.interval = interval  # 任务执行周期(可选)

    def __str__(self):
        return f'Task(name={self.name}, timeout={self.timeout}, interval={self.interval})'


class TaskStack:
    def __init__(self):
        self.stack = []  # 初始化一个空栈

    def add_task(self, task):
        self.stack.append(task)  # 将新任务添加到栈中
        self.stack.sort(key=lambda t: t.timeout)  # 按执行时间排序,保持栈顶的任务是最早执行的任务

    def remove_task(self, task):
        self.stack.remove(task)  # 从栈中删除指定任务

    def run(self):
        current_time = time.time()  # 获取当前时间
        while self.stack and self.stack[0].timeout <= current_time:
            # 如果栈非空,且栈顶任务的执行时间早于等于当前时间,就执行该任务
            task = self.stack.pop(0)  # 弹出栈顶任务
            print(f'Running {task.name} at {task.timeout}')
            if task.interval:
                task.timeout += task.interval  # 如果任务有执行周期,就计算下次执行的时间
                self.add_task(task)  # 将任务重新添加到栈中,以便下次执行

    def __str__(self):
        return '\n'.join(str(task) for task in self.stack)

您提供的 Python 代码定义了两个类:TaskTaskStack。这些类共同实现了一个基于时间的任务执行系统,类似于一个定时任务调度器。我将逐一解释这些类及其方法的功能。

Task

Task 类用于创建任务对象。每个任务具有以下属性:

  • name:任务的名称。
  • timeout:任务应该执行的时间。
  • interval:任务的执行周期。如果提供了这个值,任务将会周期性地执行。

__str__ 方法是 Task 类的字符串表示形式,它定义了当打印 Task 对象时的输出格式。

TaskStack

TaskStack 类实现了一个任务栈,用于管理和执行 Task 对象。它具有以下方法:

  1. __init__ 方法
    初始化一个空的任务栈。

  2. add_task 方法

    • 功能:向栈中添加一个任务,并根据任务的执行时间 timeout 对栈中的任务进行排序,确保栈顶的任务是最早执行的任务。
    • 参数:task - 要添加的 Task 对象。
  3. remove_task 方法

    • 功能:从栈中移除一个任务。
    • 参数:task - 要移除的 Task 对象。
  4. run 方法

    • 功能:执行任务。它会不断检查栈顶的任务是否到了执行时间(timeout),如果是,则执行该任务。对于有执行周期(interval)的任务,计算下次执行时间并重新添加到栈中,以便下次执行。
  5. __str__ 方法
    提供 TaskStack 对象的字符串表示形式,显示栈中所有任务的详情。

当调用 task_stack.run() 时,代码会执行到期的任务。对于周期性任务(例如 task2),它会在执行后计算下一次执行的时间并再次加入栈中等待执行。

这个系统适用于管理和执行基于时间的任务,特别是在需要周期性执行的场景中。

task1 = Task("Task 1", time.time() + 5)
task2 = Task("Task 2", time.time() + 10, 2)

stack = TaskStack()
stack.add_task(task1)
stack.add_task(task2)

print(stack)  # 打印任务栈中的任务信息

stack.run()  # 执行任务

print(stack)  # 打印任务栈中的任务信息
Task(name=Task 1, timeout=1704110116.3876796, interval=None)
Task(name=Task 2, timeout=1704110121.387707, interval=2)
Task(name=Task 1, timeout=1704110116.3876796, interval=None)
Task(name=Task 2, timeout=1704110121.387707, interval=2)

代码详解:上述代码实例化了两个任务 task1task2,并将它们添加到 TaskStack 实例 stack 中。然后,代码打印了任务栈中的任务信息,执行了任务,并再次打印了任务栈中的任务信息。我将逐步解释这段代码的执行流程。

  1. 创建任务 task1task2

    • task1 被设置为在当前时间之后 5 秒执行。
    • task2 被设置为在当前时间之后 10 秒执行,并且每 2 秒执行一次(周期性任务)。
  2. 将任务添加到 TaskStack

    • task1task2 被添加到任务栈 stack 中。
    • 根据任务的 timeout 属性,任务栈会自动排序,以确保最早执行的任务位于栈顶。
  3. 第一次打印任务栈中的任务信息

    • 这将展示 stack 中当前排列的任务。由于 task1timeout 更早,它将排在 task2 之前。
  4. 执行 stack.run()

    • 这个调用会检查并执行到期的任务。具体行为取决于代码执行时的当前时间。
    • 如果在 task1timeout 之后调用 runtask1 将被执行并从栈中移除。
    • 如果当前时间还没到 task2timeout,它不会被执行。如果已经到达或超过 task2timeouttask2 将被执行,并因为它是周期性任务,它将被重新添加到栈中,其 timeout 更新为下一个周期的时间。
  5. 第二次打印任务栈中的任务信息

    • 这将展示 stack.run() 执行后任务栈的当前状态。
    • 根据 stack.run() 调用时的具体时间和任务的执行情况,可能会看到 task1 被移除,task2timeout 被更新。

请注意,实际的执行情况取决于您调用 stack.run() 时的确切时间。如果这段代码是立即执行的(即在创建任务后不久),那么很可能 task1 将会被执行而 task2 则还未到执行时间。如果有一段延迟后再调用 stack.run(),则两个任务都可能执行,且 task2 将会根据其周期性计划被重新安排。

提问: 也就是说如果我在创建以上任务的5秒内执行代码,那么我的任务都不会执行,这时候任务列表不会有变化

是的,您的理解解是正确的。如果您在创建任务之后的 5 秒内执行这段代码,那么由于 task1task2 的执行时间 timeout 都尚未到达,这段时间内调用 stack.run() 将不会执行任何任务。

在这种情况下,任务列表(任务栈)将保持不变,因为:

  1. task1 的执行时间设置在创建后 5 秒,所以在这 5 秒内它不会被执行。
  2. task2 的执行时间设置在创建后 10 秒,所以在这 5 秒内它同样不会被执行。

因此,当您在创建任务后的 5 秒内执行这段代码时,第一次和第二次打印任务栈中的任务信息将会显示相同的内容,即包含未执行的 task1task2

其他:Python 中的 append(), remove(), 和 pop() 函数介绍。这些函数都是 Python 列表对象的内置方法,用于操作列表中的元素。

  1. append() 函数

    • 用途append() 用于在列表的末尾添加一个元素。
    • 语法list.append(element)
    • 参数
      • element:这是您想要添加到列表末尾的元素。
    • 返回值:这个方法没有返回值,但会修改原列表。

    示例

    fruits = ['apple', 'banana', 'cherry']  
    fruits.append('orange')  
    # 现在 fruits = ['apple', 'banana', 'cherry', 'orange']  
    
  2. remove() 函数

    • 用途remove() 用于删除列表中的第一个匹配项(即找到的第一个指定值)。
    • 语法list.remove(element)
    • 参数
      • element:要从列表中删除的元素。
    • 返回值:这个方法没有返回值,但会修改原列表。

    示例

    numbers = [1, 2, 3, 2, 4]  
    numbers.remove(2)  
    # 现在 numbers = [1, 3, 2, 4]  
    
  3. pop() 函数

    • 用途pop() 用于删除列表中的一个元素(默认是最后一个),并返回该元素的值。
    • 语法list.pop([index])
    • 参数
      • index(可选):要删除的元素的索引。默认值是 -1,表示删除最后一个元素。
    • 返回值:这个方法返回被删除的元素的值。

    示例

    colors = ['red', 'green', 'blue']  
    removed_color = colors.pop()  
    # 现在 colors = ['red', 'green']  
    # removed_color = 'blue'  
    

    如果指定索引:

    colors = ['red', 'green', 'blue']  
    removed_color = colors.pop(1)  
    # 现在 colors = ['red', 'blue']  
    # removed_color = 'green'  
    

这些方法是处理列表时常用的,它们可以让您更有效地管理列表中的数据。

可以看到,任务栈中的任务信息首先按照执行时间排序,然后依次执行任务并更新下次执行的时间。

上述代码中我们定义了 Task 类和 TaskStack 类。Task 类用于存储定时任务的相关信息,包括任务名称、执行时间和执行周期。TaskStack 类用于管理定时任务的栈,支持添加任务、删除任务和运行任务等操作。在运行任务时,我们首先获取当前时间,然后不断循环,直到栈为空或者栈顶任务的执行时间晚于当前时间为止。如果栈非空,我们就依次弹出栈中的任务,并执行任务。如果任务有执行周期,我们就计算下次执行的时间,并把任务重新添加到栈顶中。

4.案例讲解 : 如何用“栈”来处理浏览器的历史记录?

实现思路可以概括为:
当用户访问新网页时,将该网页地址压入历史记录栈中;当用户点击返回按钮时,弹出历史记录栈顶元素,将其压入后退记录栈中,并返回历史记录栈的新栈顶元素;
当用户点击前进按钮时,弹出后退记录栈顶元素,将其压入历史记录栈中,并返回后退记录栈的新栈顶元素。
这种基于栈的实现方式可以有效地管理网页历史记录,方便用户在访问网页时进行前进和后退操作.

class Browser:
    def __init__(self):
        self.history_stack = []  # 历史记录栈
        self.forward_stack = []  # 后退记录栈

    def visit(self, url):
        # 将新的访问记录添加到历史记录栈中
        self.history_stack.append(url)

    def back(self):
        if len(self.history_stack) > 1:
            # 弹出当前页面并加入后退记录栈
            current_page = self.history_stack.pop()
            self.forward_stack.append(current_page)
            # 因为要回退到,所以返回上一个历史记录
            return self.history_stack[-1]
        else:
            # 如果历史记录栈只剩一个元素,那么就不能再返回了
            return None

    def forward(self):
        if len(self.forward_stack) > 0:
            # 弹出当前页面并加入历史记录栈
            current_page = self.forward_stack.pop()
            self.history_stack.append(current_page)
            # 返回前进的页面
            return current_page
        else:
            # 如果后退记录栈为空,那么就不能再前进了
            return None

    def print_history(self):
        print('History:', self.history_stack)
        print('Forward:', self.forward_stack)

首先,在__init__方法中,我们创建了两个空的列表:history_stack和forward_stack,用于存储浏览器的历史记录和后退记录。

visit方法接收一个URL作为参数,并将该URL添加到历史记录栈history_stack中。

back方法用于回退到上一个历史记录页面。如果历史记录栈history_stack中的记录多于一个,我们从栈顶弹出当前页面,并将其添加到后退记录栈forward_stack中。然后返回历史记录栈history_stack中的上一个页面作为要回退到的页面。如果历史记录栈只有一个元素,即当前页面是最早访问的页面,我们无法再回退,此时返回None。

forward方法用于前进到下一个页面。如果后退记录栈forward_stack中有记录,我们从栈顶弹出当前页面,并将其添加到历史记录栈history_stack中。然后从后退记录栈中取出下一个页面作为要前进到的页面,并返回该页面。如果后退记录栈为空,则无法再前进,此时返回None。

print_history方法用于打印当前浏览器的历史记录和后退记录栈。

browser = Browser()

browser.visit("https://www.google.com")
browser.visit("https://www.yahoo.com")
browser.visit("https://www.bing.com")

print("初始状态:")
browser.print_history()

print("回退:")
print(browser.back())

print("回退:")
print(browser.back())

print("前进:")
print(browser.forward())

print("访问新页面:")
browser.visit("https://www.wikipedia.org")

print("最新状态:")
browser.print_history()
初始状态:
History: ['https://www.google.com', 'https://www.yahoo.com', 'https://www.bing.com']
Forward: []
回退:
https://www.yahoo.com
回退:
https://www.google.com
前进:
https://www.yahoo.com
访问新页面:
最新状态:
History: ['https://www.google.com', 'https://www.yahoo.com', 'https://www.wikipedia.org']
Forward: ['https://www.bing.com']

这段示例代码模拟了在浏览器中访问多个网页、回退和前进的过程。我们可以通过visit方法访问网页,通过back方法回退到上一个页面,通过forward方法前进到下一个页面,通过print_history方法打印当前浏览器的历史记录和后退记录栈的状态。

提问:back方法的current_page是当前页面,函数返回操作执行后即将显示的页面。而forward方法的current_page就是执行操作后即将显示的页面,返回的也是这个页面?

是的,您的理解是正确的。让我们更明确地解释一下 backforward 方法的行为:

  1. back 方法

    • current_page 是在执行后退操作时的当前页面,即历史记录栈(history_stack)的顶部元素。
    • 当执行后退操作时,current_page 被移出历史记录栈并推入前进栈(forward_stack)。
    • 方法返回的是操作执行后即将显示的页面,也就是现在历史记录栈的新顶部元素。
  2. forward 方法

    • current_page 是在执行前进操作时的页面,即前进栈(forward_stack)的顶部元素。
    • 当执行前进操作时,current_page 被移出前进栈并重新推回历史记录栈。
    • 方法返回的是操作执行后即将显示的页面,也就是 current_page,此时它已经被重新放回历史记录栈的顶部。

这种设计模拟了大多数浏览器的后退和前进按钮的行为。在使用后退按钮时,当前页面移入前进栈,同时历史记录栈的上一个页面变成了当前页面。相反,在使用前进按钮时,前进栈的顶部页面移回历史记录栈,并成为当前页面。

5.闯关题

STEP1:根据要求完成题目

Q1. (单选)栈和队列都是什么类型的数据结构?
A. 动态数据结构
B. 静态数据结构
C. 线性数据结构
D. 非线性数据结构

Q2. (单选)下列哪项不是栈的特点?
A. 先进后出
B. 后进先出
C. 支持插入和删除操作
D. 只能在栈底进行插入和删除操作

Q3. (单选)如何在 Python 中实现一个栈?
A. 利用列表的 append() 和 pop() 方法
B. 利用列表的 extend() 和 remove() 方法
C. 利用元组的 append() 和 pop() 方法
D. 利用元组的 extend() 和 remove() 方法

Q4. (单选)下列哪种情况适合采用队列数据结构?
A. 消费者和生产者之间的异步消息传递
B. 系统中的前进后出操作
C. 一般类型的后进先出操作
D. 需要快速随机访问存储元素的列表

Q5.(判断对错) 栈也是一种数据呈树形的一种数据结构 (T/F)
Q6.(判断对错)栈这种最后添加的数据最先被取出,即“后进先出”的结构 (T/F)
Q7.(判断对错)列表可以直接用来实现栈的功能,只需要在列表的末尾添加元素,用 pop() 方法从列表末尾删除元素即可。这样,列表就变成了一个简单的 LIFO 数据结构 (T/F)
Q8.(判断对错)队列这种最先进去的数据最先被取来,即“先进先出”的结构 (T/F)


# 如何通过“队列”实现数据的缓存,以下是实现代码:


import queue
import time
import random
import threading

# 创建一个队列,用于数据缓存
cache_queue = queue.Queue()

# 生产者线程:向队列中不断添加数据
def producer():
    while True:
        # 生成随机数据
        data = random.randint(1, 1000)
        
        # 将数据放入队列
        cache_queue.put(data)
        
        print("Produced data:", data)
        
        time.sleep(1)  # 模拟产生数据的时间间隔

# 消费者线程:从队列中不断取出数据进行处理
def consumer():
    
    while True:
        # 从队列中取出数据
        data = cache_queue.get()
        
        print("Consumed data:", data)
        
        # 数据处理逻辑示例:打印数据和模拟处理时间
        print("Processing data...")
        time.sleep(2)  # 模拟处理数据的时间间隔
        print("Data processing finished")
        
        cache_queue.task_done()  # 标记队列中的任务已完成

# 主线程:启动生产者和消费者线程
if __name__ == '__main__':
    producer_thread = threading.Thread(target=producer)
    # q9题目 : 通过threading模块生成变量名consumer_thread的对象
    
    # 启动线程
    producer_thread.start()
    consumer_thread.start()

在每次处理完一个数据后,我们调用了cache_queue.task_done()方法来标记任务的完成。这样做的目的是保证在队列中所有的数据被处理完之前,主线程会一直阻塞,确保所有任务的完成。
需要注意的是,当队列中没有任务时,消费者线程将会自动阻塞等待新的任务到来。当生产者线程不断产生数据时,消费者线程会一直从队列中取出数据进行处理。
这样就实现了一个数据缓存系统,并通过队列和多线程实现了数据的生产和消费过程

如何通过“队列”实现数据的缓存,上面是实现代码

观察上面的代码,完成下面的单选题(注意查看前后代码)

Q9.代码第46行为空,现在需要实现 通过threading模块生成变量名为consumer_thread的对象,下面哪个选项为正确代码,选择正确选项并把结果赋值给a9

A : consumer_thread = threading.Thread(target=consumer)

B : consumer_thread = threading.Thread(target=consumer())

C : consumer_thread = threading.Thread(queue=consumer())

D : consumer_thread = threading.Thread(queue=consumer)

E : consumer_thread = threading.Thread(queue == consumer)

import queue
import time
import random
import threading

# 创建一个队列,用于数据缓存
cache_queue = queue.Queue()

# 生产者线程:向队列中不断添加数据
def producer():
    while True:
        # 生成随机数据
        data = random.randint(1, 1000)
        
        # 将数据放入队列
        cache_queue.put(data)
        
        print("Produced data:", data)
        
        time.sleep(1)  # 模拟产生数据的时间间隔

# 消费者线程:从队列中不断取出数据进行处理
def consumer():
    while True:
        # 从队列中取出数据
        data = cache_queue.get()
        
        print("Consumed data:", data)
        
        # 数据处理逻辑示例:打印数据和模拟处理时间
        print("Processing data...")
        time.sleep(2)  # 模拟处理数据的时间间隔
        print("Data processing finished")
        
        cache_queue.task_done()  # 标记队列中的任务已完成

# 主线程:启动生产者和消费者线程
if __name__ == '__main__':
    producer_thread = threading.Thread(target=producer)
    # 创建消费者线程
    consumer_thread = threading.Thread(target=consumer)
    
    # 启动线程
    producer_thread.start()
    consumer_thread.start()

    # 等待线程完成
    producer_thread.join()
    consumer_thread.join()

Produced data: 785
Consumed data: 785
Processing data...
Produced data: 320
Produced data: 479
Data processing finished
Consumed data: 320


Produced data: 879
Produced data: 752
Data processing finished
Consumed data: 403
Processing data…
Produced data: 824

---------------------------------------------------------------------------

KeyboardInterrupt                         Traceback (most recent call last)

<ipython-input-15-0e0d4ddf51cf> in <module>
     46 
     47     # 等待线程完成
---> 48     producer_thread.join()
     49     consumer_thread.join()


/opt/conda/lib/python3.6/threading.py in join(self, timeout)
   1054 
   1055         if timeout is None:
-> 1056             self._wait_for_tstate_lock()
   1057         else:
   1058             # the behavior of a negative timeout isn't documented, but


/opt/conda/lib/python3.6/threading.py in _wait_for_tstate_lock(self, block, timeout)
   1070         if lock is None:  # already determined that the C code is done
   1071             assert self._is_stopped
-> 1072         elif lock.acquire(block, timeout):
   1073             lock.release()
   1074             self._stop()


KeyboardInterrupt: 

在这段代码中,我们创建了一个消费者线程 consumer_thread,它运行 consumer 函数。这个函数负责从队列 cache_queue 中获取数据,执行一些处理逻辑(这里是简单地打印消息和等待一段时间),然后标记队列中的任务为已完成。这样,生产者线程和消费者线程将并行运行,模拟了一个生产者-消费者问题的经典解决方案。

#填入你的答案后运行
a1 = 'C'  # 如 a1= 'A'
a2 = 'D'  # 如 a2= 'A'
a3 = 'A'  # 如 a3= 'A'
a4 = 'A'  # 如 a4= 'A'
a5 = 'F'  # 如 a5= 'F',请注意大小写
a6 = 'T'  # 如 a5= 'T',请注意大小写
a7 = 'T'  # 如 a5= 'F',请注意大小写
a8 = 'T'  # 如 a5= 'T',请注意大小写
a9 = 'A'  # 如 a9= 'B'

STEP2:将结果保存为 csv 文件
csv 需要有两列,列名:id、answer。其中,id 列为题号,如 q1、q2;answer 列为 STEP1 中各题你计算出来的结果。💡 这一步的代码你不用做任何修改,直接运行即可。

# 生成 csv 作业答案文件
def save_csv(a1, a2, a3, a4, a5,a6,a7,a8,a9):
    import pandas as pd
    df = pd.DataFrame({"id": ["q1", "q2", "q3", "q4","q5","q6","q7","q8","q9"], "answer": [a1, a2, a3,a4,a5,a6,a7,a8,a9]})
    df.to_csv("answer_ago_1_2.csv", index=None)

save_csv(a1, a2, a3,a4,a5,a6,a7,a8,a9)  # 运行这个cell,生成答案文件;该文件在左侧文件树project工作区下,你可以自行右击下载或者读取查看

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1349416.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Cloud Function SpEL注入漏洞(CVE-2022-22963)分析

一、概述 2022年3月24日&#xff0c;Pivotal修补了Spring Cloud Function中一个关键的服务器端代码注入漏洞&#xff08;Spring表达式语言注入&#xff09;&#xff0c;该漏洞有可能导致系统被攻击。Spring是一种流行的开源Java框架&#xff0c;该漏洞与另一个相关的远程代码执…

rime中州韵 help lua Translator

lua 是 Rime中州韵/小狼毫输入法强大的武器&#xff0c;掌握如何在Rime中州韵/小狼毫中使用lua&#xff0c;你将体验到什么叫 随心所欲。 先看效果 在 rime中州韵 输入效果一览 中的 &#x1f447; help效果 一节中&#xff0c; 我们看到了在Rime中州韵/小狼毫输入法中输入 h…

07-2-接口文档管理工具-swagger注解使用__ev

swagger参考demo package com.example.swagger2.controller;import com.example.swagger2.exception.SwaggerException; import com.example.swagger2.model.User; import io.swagger.annotations.*; import org.springframework.web.bind.annotation.*;import java.util.Has…

MySQL数据库索引优化

一、引言 1. 索引的重要性 MySQL数据库索引的重要性主要体现在&#xff0c;一是查询速度优化&#xff0c;索引可以极大地提高查询速度。对于没有索引的表&#xff0c;MySQL必须进行全部扫描来找到所需的行&#xff0c;如果表中数据量很大&#xff0c;那么通常很慢。通过适当的…

Python pycharm编辑器修改代码字体

在pycharm编辑器下修改代码字体&#xff0c;可以按照以下步骤&#xff1a; 点开上图所示的菜单&#xff0c; 再点击File->Settings&#xff0c;进入设置页面。 我们找到Editor下的Font并点选&#xff0c;然后我们就可以在右侧修改字体相关配置了。 这里建议使用等宽字体&…

数据结构第1章 线性表

名人说&#xff1a;莫听穿林打叶声&#xff0c;何妨吟啸且徐行。—— 苏轼《定风波莫听穿林打叶声》 本篇笔记整理&#xff1a;Code_流苏(CSDN)&#xff08;一个喜欢古诗词和编程的Coder&#x1f60a;&#xff09; 目录 0、思维导图线性表1、顺序存储1&#xff09;顺序表2&…

自定义html5中日期选取器的样式

自定义html5中日期选取器的样式 1. 前言1.1 关于 h5 的新特性1.2 使用浏览器 2. html5中日期选取器默认样式3. 自定义日期样式3.1 简单定义3.2 花式样式定义 4. 改变日期格式5. 参考6. 关于低版本浏览器隐藏小三角 1. 前言 1.1 关于 h5 的新特性 可看下面的文章 HTML5 新特性之…

算法基础之能被整除的数

能被整除的数 核心思想&#xff1a; 容斥原理 总面积 1-23-4…. 总集合元素中个数 1-23-4…. #include<iostream>#include<cstring>#include<algorithm>using namespace std;const int N 20;typedef long long LL;int p[N];int main(){int n,m;cin&…

L1-075:强迫症

题目描述 小强在统计一个小区里居民的出生年月&#xff0c;但是发现大家填写的生日格式不统一&#xff0c;例如有的人写 199808&#xff0c;有的人只写 9808。有强迫症的小强请你写个程序&#xff0c;把所有人的出生年月都整理成 年年年年-月月 格式。对于那些只写了年份后两位…

Qt重载事件

重载event 事件类型 (EventType) 事件类型是 QEvent 类的一个枚举 &#xff0c;包含了 Qt 能够处理的所有不同类型的事件。这个枚举包括但不限于以下常见类型&#xff1a; QEvent::MouseButtonPress: 鼠标按钮按下事件。QEvent::MouseButtonRelease: 鼠标按钮释放事件。Q…

BikeDNA(三) OSM数据的内在分析2

BikeDNA&#xff08;三&#xff09; OSM数据的内在分析2 1.数据完整性 见上一篇BikeDNA&#xff08;二&#xff09; OSM数据的内在分析1 2.OSM标签分析 见上一篇BikeDNA&#xff08;二&#xff09; OSM数据的内在分析1 3.网络拓扑结构 本节探讨数据的几何和拓扑特征。 例…

2023年“中银杯”四川省职业院校技能大赛“云计算应用”赛项样题卷②

2023年“中银杯”四川省职业院校技能大赛“云计算应用”赛项&#xff08;高职组&#xff09; 样题&#xff08;第2套&#xff09; 目录 2023年“中银杯”四川省职业院校技能大赛“云计算应用”赛项&#xff08;高职组&#xff09; 样题&#xff08;第2套&#xff09; 模块…

基于grpc从零开始搭建一个准生产分布式应用(8) - 01 - 附:GRPC公共库源码

开始前必读&#xff1a;​​基于grpc从零开始搭建一个准生产分布式应用(0) - quickStart​​ common包中的源码&#xff0c;因后续要用所以一次性全建好了。 一、common工程完整结构 二、引入依赖包 <?xml version"1.0" encoding"UTF-8"?> <p…

【Pytorch】Pytorch或者CUDA版本不符合问题解决与分析

NVIDIA CUDA Toolkit Release Notes Package installation issues INSTALL PYTORCH 先声毒人&#xff1a;最好资料就是上面三份资料&#xff0c;可以通过官网明确的获取一手信息&#xff0c;你所遇到的99%的问题都可以找到&#xff0c;明确的解决方案&#xff0c;建议最好看…

2024主流的免费电脑数据恢复软件EasyRecovery

EasyRecovery绿色版是一款非常专业的电脑数据恢复工具。它可以全面恢复删除丢失数据&#xff0c;能对电脑误删文件恢复、格式化硬盘数据恢复、手机U盘数据恢复等&#xff0c;能恢复包括文档、表格、图片、音视频等各种文件&#xff0c;此版本经过处理&#xff0c;可永久免费使用…

[ffmpeg系列 02] 音视频基本知识

一 视频 RGB&#xff1a; AV_PIX_FMT_RGB24, ///< packed RGB 8:8:8, 24bpp, RGBRGB… Y&#xff1a;明亮度, Luminance或luma, 灰阶图&#xff0c; UV&#xff1a;色度&#xff0c;Chrominance或Chroma。 YCbCr: Cb蓝色分量&#xff0c;Cr是红色分量。 取值范围&#xff…

【索引的数据结构】第1章节:B+Tree存储结构

目录结构 之前整篇文章太长&#xff0c;阅读体验不好&#xff0c;将其拆分为几个子篇章。 本篇章讲解 BTree 存储结构。 什么是索引 可以简单理解为索引好比一本书的目录&#xff0c;通过目录我们可以快速定位到我们要查看的章节。 MySQL 中的数据同样也是根据索引分类&…

ROS TF坐标变换 - 位姿描述与消息类型

目录 一、位姿描述二、位姿相关消息体类型2.1 geometry_msgs/TransformStamped2.2 geometry_msgs/PoseStamped 在机器人系统中&#xff0c;有许多运动机构和传感器&#xff0c;为了描述他们之间的相对位姿关系&#xff0c;分别为他们定义了各自的坐标系&#xff0c;通过坐标系转…

合伙企业法关于合伙企业的要求

合伙协议可以载明合伙企业的经营期限和合伙人争议的解决方式。 合伙协议经全体合伙人签名、盖章后生效。合伙人依照合伙协议享有权利&#xff0c;承担责任。 经全体合伙人协商一致&#xff0c;可以修改或者补充合伙协议。 申请合伙企业设立登记&#xff0c;应当向企业登记机关提…

B2005 字符三角形(python)

a input() print( a) print( a a a) print(a a a a a)python中默认输入的是字符型&#xff0c;第一句就是输入了一个字符赋给a python中单引号内的也是字符串&#xff0c;用print输出需要连接的字符串时用加号加在后面即可