[LeetCode周赛复盘] 第 107 场双周赛20230624

news2024/11/19 3:50:02

[LeetCode周赛复盘] 第 107 场双周赛20230624

    • 一、本周周赛总结
    • 6898. 字符串连接删减字母
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 6895. 构造最长的新字符串
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 6898. 字符串连接删减字母
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 6468. 统计没有收到请求的服务器数目
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • 参考链接

一、本周周赛总结

  • T1 哈希表模拟。
  • T2 记忆化搜索。
  • T3 dp。
  • T4 离线+滑窗。
    在这里插入图片描述

6898. 字符串连接删减字母

6898. 字符串连接删减字母

1. 题目描述

在这里插入图片描述

2. 思路分析

按题意模拟即可。

  • 注意每个单词只能匹配一次,记得删除。

3. 代码实现

class Solution:
    def maximumNumberOfStringPairs(self, words: List[str]) -> int:
        p = set()
        ans = 0
        for w in words:
            s = w[::-1]
            if s in p:
                ans += 1
                p.remove(s)
            else:
                p.add(w)
        return ans 

6895. 构造最长的新字符串

6895. 构造最长的新字符串

1. 题目描述

在这里插入图片描述

2. 思路分析

记忆化搜索
  • 令f(x,y,z,last)为用xyz个对应串,构造尾巴为last=a/b字符的最长串长度。
  • 那么若last='a’则只能用x,可以从f(x-1,y,z,last=‘b’)转移而来,若转移不了,则可以只用一个x,最山是2;
  • 若last=‘b’则可以用y/z,同理从对应尾字符转移而来。

3. 代码实现

class Solution:
    def longestString(self, x: int, y: int, z: int) -> int:

        @cache
        def f(x, y, z, last):                         
            ans = -inf
            if last == 'a':                
                if x > 0 :
                    ans = max(ans,f(x-1,y,z,'b')+2,2)
            elif last == 'b':                
                if y>0:
                    ans = max(ans,f(x,y-1,z,'a')+2,2)
                if z>0:
                    ans = max(ans,f(x,y,z-1,'b')+2,2)
            
            return ans 
          
        return max(f(x,y,z,'a'),f(x,y,z,'b'))

6898. 字符串连接删减字母

6898. 字符串连接删减字母

1. 题目描述

在这里插入图片描述

2. 思路分析

  • dp。
  • 由于连接顺序是固定的,影响只在之前串的首尾字符,那么可以记录每次转移完,首尾字符分别为x,y时的最小长度,然后进行分类讨论。
  • 令f[i][(x,y)]为用了前i个字符串,首尾分别为xy时最小长度。
  • 转移时,尝试把当前串s和前边所有串进行连接。
  • 由于只有小写字符,因此状态数最多26*26,转移1000次即可。

  • 实现时图方便用了defaultdict,并且可以滚动省去一维。

3. 代码实现

class Solution:
    def minimizeConcatenatedLength(self, words: List[str]) -> int:
        n = len(words)
        f = defaultdict(lambda : inf)
        a = words[0]
        f[(a[0],a[-1])] = len(a)
        
        for i in range(1,n):
            a = words[i]
            p = len(a)
            g = defaultdict(lambda : inf)
            for (s,e),v in f.items():
                if a[0] == e:
                    g[(s,a[-1])] = min(g[(s,a[-1])], v+p-1)
                else:
                    g[(s,a[-1])] = min(g[(s,a[-1])], v+p)
                if a[-1] == s:
                    g[(a[0],e)] = min(g[(a[0],e)],v+p-1)
                else:
                    g[(a[0],e)] = min(g[(a[0],e)],v+p)
            f = g
        return min(f.values())

6468. 统计没有收到请求的服务器数目

6468. 统计没有收到请求的服务器数目

1. 题目描述

在这里插入图片描述

2. 思路分析

  • 离线+滑窗。
  • 读题愣了一下,logs这个变量名也有点坑人。敲成了log运行,但是白板不报错,RE 3次。
  • 发现把询问离线,把事件排序,然后用cnt记录窗口内每个服务器的出现次数即可。
  • 然后用n减去出现了几个服务器就是没出现的个数。

3. 代码实现

class Solution:
    def countServers(self, n: int, logs: List[List[int]], x: int, queries: List[int]) -> List[int]:
        m = len(queries)
        ans = [0]*m
        j = 0
        logs.sort(key=lambda xx:xx[1])
        q = deque()
        cnt = Counter()
        for v,i in sorted([(v,i) for i,v in enumerate(queries)] ):
            while j < len(logs) and logs[j][1] <= v:
                q.append(j)
                cnt[logs[j][0]] += 1
                j += 1
            while q and logs[q[0]][1]<v-x:
                p = logs[q.popleft()][0]
                cnt[p] -= 1
                if not cnt[p]:
                    del cnt[p]
            ans[i] = n - len(cnt)
        return ans                                    

参考链接

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

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

相关文章

Linux系统之部署Dailynotes个人笔记管理工具

Linux系统之部署Dailynotes个人笔记管理工具 一、Dailynotes介绍二、本地环境介绍2.1 本地环境规划2.2 本次实践介绍 三、检查本地环境3.1 检查本地操作系统版本3.2 检查系统内核版本3.3 检查本地yum仓库状态 四、部署Node.js 环境4.1 下载Node.js安装包4.2 解压Node.js安装包4…

ThreadPoolExecutor的应用

前面描述的线程池的创建方式大都是Executors类中创建出来&#xff0c;基于ThreadPoolExecutor去new出来实现的。 我们为什么要自定义线程池 在线程池ThreadPoolExecutor中提供了7个参数&#xff0c;都作为非常核心的属性&#xff0c;在线程池去执行任务的时候&#xff0c;每个…

Nginx-Goaccess(实时日志服务)

goaccess的功能 1、使用webscoket协议传输&#xff08;双向传输协议&#xff09;2、基于终端的快速日志分析器3、通过access.log快速分析和查看web服务的统计信息、PV、UV4、安装简单、操作简易、界面炫酷5、按照日志统计访问次数、独立访客数量、累计消耗的带宽6、统计请求次…

物理引擎--Open Dynamics Engine(ODE)

物理引擎--Open Dynamics Engine--ODE 1 介绍1.1 概述1.2 代码1.3 wiki1.4 特征1.5 许可 2 安装使用3 概念3.1 背景3.2 刚体3.2.1 岛屿和禁用实体 3.3 一体化3.4 积分器3.5 关节和约束3.6 关节组3.7 关节误差和误差减少参数 (ERP) Joint error and the Error Reduction Paramet…

Scala函数式编程【从基础到高级】

目录 函数基础 基本语法 函数参数 函数至简原则 至简原则细节 函数高级 高阶函数 函数的3种高阶用法&#xff1a; 1、函数作为值传递 2、函数作为参数传递 匿名函数作参数传递 3、函数作为返回值传递 匿名函数的至简规则 高阶函数的应用 案例-将数组中的元素全部…

【LeetCode】 动态规划 刷题训练(三)

文章目录 931. 下降路径最小和题目解析状态转移方程完整代码 64. 最小路径和题目解析状态转移方程完整代码 174. 地下城游戏题目解析状态转移方程完整代码 931. 下降路径最小和 点击查看&#xff1a;下降路径最小和 给你一个 n x n 的 方形 整数数组 matrix &#xff0c;请你找…

chatgpt赋能python:Python搜题软件:为你量身定制的智能搜索助手

Python搜题软件&#xff1a;为你量身定制的智能搜索助手 随着互联网的普及&#xff0c;我们每天需要面对海量的信息&#xff0c;其中包含了我们所需要的一切答案。但是&#xff0c;如何快速而准确地找到这些答案呢&#xff1f;这时候&#xff0c;一款智能化的搜题软件就非常有…

【不推荐】win 安装 rust 1.70 (MSVC)

目录 一、下载二、安装三、配置环境变量四、检查是否安装成功五、参考文章 一、下载 官网地址&#xff1a;https://www.rust-lang.org/zh-CN/ https://forge.rust-lang.org/infra/other-installation-methods.html 历史版本下载地址&#xff1a; 二、安装 注意&#xff1a;安…

Redis:redis基于各大实战场景下的基本使用

文章目录 前言String 命令实战1.业务缓存对应redis中的指令伪代码 2.分布式锁对应redis中的指令伪代码 3.限流对应redis中的指令伪代码 List 命令实战1.提醒功能对应Redis中的指令伪代码 2.热点列表对应Redis中的指令伪代码 Hash 命令实战1.用户资料缓存对应redis中的指令伪代码…

RabbitMQ学习笔记(尚硅谷)

文章目录 一. 消息队列1. 定义2. 作用2.1 流量消峰2.2 应用解耦2.3 异步处理 3. 分类4. MQ的选择5. RabbitMQ5.1 概念5.2 四大概念5.3 六大模式5.4 RabbitMQ 工作原理5.5 安装 6. 代码实现 二. Hello World (简单模式)1. 生产者代码2. 消费者代码 三. Work Queues (工作队列模式…

OUC编译原理实验报告 实验5:用Yacc设计语法分析器1 实验6:用Yacc设计语法分析器2

编译原理实验报告 实验5&#xff1a;用Yacc设计语法分析器1 实验6&#xff1a;用Yacc设计语法分析器2 中国海洋大学编译原理实验2023春 仅供同学参考思路 请勿直接抄袭 否则可能喜提0分 目录 文章目录 编译原理实验报告目录一.实验目的二.实验内容实验5实验6 三.实验要求实…

RISCV Reader笔记_2 RV32I

RV32I 完整的RV32I指令集可以用下面的式子中出现单词的首字母表示&#xff1a; 比如这一条&#xff1a; set less than {immediate} {unsigned} 也就是slt slti sltu sltiu这4个指令。 RISCV指令格式如下。R 寄存器操作&#xff0c;I 立即数或load访存&#xff0c;S store访…

C51单片机期末复习第八章单片机接口技术

一 总线&#xff1a; 传送同类信息的连线 三总线&#xff1a; 地址总线AB&#xff0c;数据总线DB,控制总线CB 目录(ppt给的没啥用&#xff0c;乱还不全)&#xff1a; 8.1 单片机的系统总线 8.2 简单并行I/O口扩展 8.3 可编程并行I/O口扩展 8.4 D/A转换与DAC0832应用 8…

稀疏表:最大公约数

问题描述 给定一个数组, 每次操作可以选择数组中任意两个相邻的元素 x , y x, y x,y 并将其 中的一个元素替换为 gcd ⁡ ( x , y ) \operatorname{gcd}(x, y) gcd(x,y), 其中 gcd ⁡ ( x , y ) \operatorname{gcd}(x, y) gcd(x,y) 表示 x x x 和 y y y 的最大公约数。 请…

MIT 6.S081 教材第五章内容 -- 中断与设备驱动--下

MIT 6.S081 教材第五章内容 -- 中断与设备驱动--下 引言关于RISC-V特权级架构说明RISC-V特权模式OpenSBI介绍RISC-V启动过程RISC-V中的异常M模式下的异常1. 硬件中断的处理&#xff08;以时钟中断为例&#xff09;2. M模式下的异常相关寄存器3. 同步异常的处理 S模式下的异常1.…

chatgpt赋能python:Python散点图介绍:如何用Python绘制散点图?

Python散点图介绍&#xff1a;如何用Python绘制散点图&#xff1f; Python是一门流行的编程语言&#xff0c;用于解决各种问题和编写各种应用程序。其中&#xff0c;数据可视化是Python应用程序中非常重要的组成部分。散点图是最常用的数据可视化图形之一&#xff0c;它能够清…

拓扑排序:神经网络

题目链接 神经网络 题目大意 在兰兰的模型中&#xff0c;神经网络就是一张有向图&#xff0c;图中的节点称为神经元&#xff0c;而且两个神经 元之间至多有一条边相连&#xff0c;下图是一个神经元的例子&#xff1a; 图中&#xff0c; X 1 — X 3 X_1—X_3 X1​—X3​是信…

从类加载到双亲委派:深入解析类加载机制与 ClassLoader

目录 前言Class 文件介绍如何生成 class 文件观察 Bytecode 方法class 文件到底是什么样的呢&#xff1f; Class 加载、链接、初始化加载、类加载器双亲委派Launcher 核心类ClassLoader 相关源码ClassLoader 相关问题自定义简单 ClassLoader自定义加密 ClassLoader打破双亲委派…

动态ip与静态ip的概念、区别、应用场景

动态ip与静态ip的区别 前言一、介绍IP地址的概念和作用1.1、IP地址的定义1.2、IP地址的作用 二、动态IP和静态IP的区别2.1、动态IP和静态IP的定义2.2、动态IP和静态IP的特点2.3、动态IP和静态IP的优缺点比较 三、动态IP和静态IP的应用场景3.1. 动态IP的应用场景3.2. 静态IP的应…

利用numpy解决解方程组的基本问题

1 问题 进入大学&#xff0c;我们接触了线性代数&#xff0c;利用线性代数解方程组比高中慢慢计算会好了许多&#xff0c;快捷许多&#xff0c;我们作为编程人员&#xff0c;有没有用python解决解方程组的办法呢&#xff1f; 2 方法 我们提出使用python的numpy解方程。 找到用于…