[ATC复盘] abc329 20231118

news2024/11/19 23:28:00

[ATC复盘] abc329 20231118

    • 总结
    • A - Spread
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • B - Next
      • 1. 题目描述
      • 2. 思路分析-
      • 3. 代码实现
    • C - Count xxx
      • 1. 题目描述
      • 2. 思路分析
      • 3. 代码实现
    • D - Election Quick Report
      • 2. 思路分析
      • 3. 代码实现
    • E - Stamp
      • 2. 思路分析
      • 3. 代码实现
    • F - Colored Ball
      • 2. 思路分析
      • 3. 代码实现
    • 六、参考链接

总结

  • 前6题除了E都挺水的。
  • A 语法题。
  • B 排序。
  • C dp计数。
  • D 贪心
  • E dp
  • F 启发式合并(模拟)

在这里插入图片描述

A - Spread

链接: A - Spread

1. 题目描述

把输入的字符串每个字符中间加空格输出。

2. 思路分析

  • join

3. 代码实现

def solve():
    s, = RS()
    print(' '.join(s))

B - Next

链接: B - Next

1. 题目描述

在这里插入图片描述

2. 思路分析-

  • 题目问出了最大之外,最大的数是哪个。
  • 就是第二大。排序即可。

3. 代码实现

def solve():
    n, = RI()
    a = sorted(set(RILST()))
    print(a[-2])

C - Count xxx

链接: C - Count xxx

1. 题目描述

在这里插入图片描述

2. 思路分析

  • 问有多少种连续相同字符的子串。如果字母a最长连续8个,那么a的连续子串有8种。
  • 那么把每种字母最长连续计数即可,我习惯用dp处理。

3. 代码实现


def solve():
    n, = RI()
    s, = RS()
    cnt = Counter([s[0]])
    f = [1] * n
    for i in range(1, n):
        if s[i] == s[i - 1]:
            f[i] += f[i - 1]
        cnt[s[i]] = max(cnt[s[i]], f[i])
    print(sum(cnt.values()))

D - Election Quick Report

链接: D - Election Quick Report
在这里插入图片描述

2. 思路分析

按顺序唱票,问当前获胜者是谁,平票取id最小的。
  • 直接计数,更新最大计数即可,注意id也一起比较。

3. 代码实现

def solve():
    n, m = RI()
    a = RILST()
    cnt = [0 for _ in range(n + 1)]
    win = [0, 0]  # 计数,-下标
    for v in a:
        cnt[v] += 1
        win = max(win, [cnt[v], -v])
        print(-win[1])

E - Stamp

链接: E - Stamp
在这里插入图片描述

2. 思路分析

已知len(t)<len(s),问s可不可以由t覆盖拼接而来。即给长为len(s)的格子,通过无限盖地毯t的方式,铺满格子,且俯视图是s。
  • 由看到m<=5,考虑dp。
  • 令f[i][0~4]表示s[i]位置能不能匹配t[j]。那么,只有s[i]==s[j]时才能匹配,另外还要满足:
    • 如果前一个位置可以匹配t[j-1],那么这里可以匹配t[j]
    • 如果j=0,那么可以从这个位置新盖一块t。
    • 如果前一个位置可以匹配t[-1],那这里可以匹配任何位置,盖完了再盖前边即可。
    • 另外注意,地毯前后不能越界,即j<=i 且m-j<=n-i。
  • 实现时可以空间优化。
  • 注意方案必须每个位置都有匹配项,不能只判断f[-1][-1]。

3. 代码实现

def solve():
    n, m = RI()
    s, = RS()
    t, = RS()
    f = [0] * m
    f[0] = s[0] == t[0]
    for i in range(1, n):
        if not sum(f):
            return print('No')
        g = [0]*m
        for j in range(min(m, i + 1)):
            if s[i] == t[j] and m - j <= n - i:
                if j == 0 or f[m-1] or f[j-1]:
                    g[j] = 1
        f = g
    print(['No', 'Yes'][f[-1]])

def solve1():
    """
    f[i][0~4]表示前缀匹配时,s[i]是否能用t[j]来匹配
    """
    n, m = RI()
    s, = RS()
    t, = RS()
    f = [[0] * m for _ in range(n)]
    f[0][0] = s[0] == t[0]
    for i in range(1, n):
        if not sum(f[i - 1]):
            return print('No')
        for j in range(min(m, i + 1)):
            if s[i] == t[j] and m - j <= n - i:
                if j == 0:
                    f[i][j] = 1
                elif f[i - 1][m - 1]:
                    f[i][j] = 1
                elif f[i - 1][j - 1]:
                    f[i][j] = 1

    print(['No', 'Yes'][f[-1][-1]])

F - Colored Ball

链接: F - Colored Ball

在这里插入图片描述

2. 思路分析

一开始每个盒子都有一种颜色的小球,q个操作,每次把a盒子所有球倒进b盒子,问b盒子每次的球数量。
  • 语法题,启发式合并,把每次移动少的那边的盒子,然后整体给盒子动位置。
  • 启发式合并均摊复杂度是O(nlgn)的。

  • 有道类似的题,更难一些,用并查集F - BOX

3. 代码实现

#    379    ms
def solve():
    n, q = RI()
    c = [0] + RILST()
    cc = [{v} for v in c]

    for _ in range(q):
        a, b = RI()
        if len(cc[a]) > len(cc[b]):
            cc[a], cc[b] = cc[b], cc[a]
        cc[b] |= cc[a]
        cc[a] = set()
        print(len(cc[b]))


#     499   ms
def solve1():
    n, q = RI()
    c = [0] + RILST()
    cc = [{v} for v in c]

    for _ in range(q):
        a, b = RI()
        if len(cc[a]) < len(cc[b]):
            for v in cc[a]:
                cc[b].add(v)
            cc[a] = set()
        else:
            for v in cc[b]:
                cc[a].add(v)
            cc[b] = cc[a]
            cc[a] = set()
        print(len(cc[b]))

六、参考链接

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

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

相关文章

Compose学习之绘制速度表盘

内心想法XX compose已经发布好久了&#xff0c;还没有用过compose写过UI&#xff0c;之前只是在官网上了解过&#xff0c;看着这可组合函数嵌套&#xff0c;我就脑袋大&#xff0c;更Flutter一个德行&#xff0c;我的内心是抵触的&#xff0c;还是觉得用XML写香&#xff0c;抱…

DPAFNet:一种用于多模式脑肿瘤分割的残差双路径注意力融合卷积神经网络

DPAFNet: A Residual Dual-Path Attention-Fusion Convolutional Neural Network for Multimodal Brain Tumor Segmentation DPAFNet&#xff1a;一种用于多模式脑肿瘤分割的残差双路径注意力融合卷积神经网络背景贡献实验方法ulti-scale context feature extraction block&…

如何在企业签名、超级签名、tf签名之间做选择

企业签名 (Enterprise Signing): 用途&#xff1a; 适用于企业内部发布应用&#xff0c;不需要经过App Store审核&#xff0c;可以通过企业内部渠道直接分发给员工或内部用户。限制&#xff1a; 仅限于企业内部使用&#xff0c;无法在App Store上发布或向外部用户分发。 超级签…

Java多线程之CAS及原子操作

一、CAS是什么&#xff1f; Java 并发机制实现原子操作有两种&#xff1a; 一种是锁&#xff0c;还有一种是CAS。 在Java中&#xff0c;锁在并发处理中占据了一席之地&#xff0c;但是使用锁有一个不好的地方&#xff0c;就是当一个线程没有获取到锁时会被阻塞挂起&…

【C++入门到精通】右值引用 | 完美转发 C++11 [ C++入门 ]

阅读导航 引言一、左值引用和右值引用1. 什么是左值&#xff1f;什么是左值引用&#xff1f;2. 什么是右值&#xff1f;什么是右值引用&#xff1f;3. move( )函数 二、左值引用与右值引用比较三、右值引用使用场景和意义四、完美转发std::forward 函数完美转发实际中的使用场景…

Spring接入Metric+Graphite+Grafana搭建监控系统

环境搭建 Metric 主要是记录操作记录&#xff0c;把数据传给Graphite&#xff0c;这个只需要引入依赖就可以了 日志收集系统&#xff0c;可以支持很多的监控系统一般在Spring项目中用其收集数据&#xff0c;可以发送到Graphite等监控系统中一般使用Merter和Timer分别记录成功…

[黑马程序员SpringBoot2]——开发实用篇1

目录&#xff1a; 手工启动热部署自动启动热部署热部署范围配置关闭热部署功能第三方bean属性绑定松散绑定常用计量单位应用bean属性校验进制数据转换规则加载测试专用属性加载测试专用配置测试类中启动web环境发送虚拟请求匹配响应执行状态匹配响应体匹配响应体(json)匹配响应…

信息系统项目管理师 第四版 第1章 信息化发展

1.信息与信息化 信息是指音讯、消息、信息系统传输和处理的对象&#xff0c;泛指人类社会传播的一切内容。来自P1 信息化是指在国家宏观信息政策指导下&#xff0c;通过信息技术开发、信息产业的发展、信息人才的配置&#xff0c;最大限度地利用信息资源以满足全社会的信息需…

一种用于脑肿瘤和组织分割的具有体积特征对齐的三维跨模态特征交互网络

A 3D Cross-Modality Feature Interaction Network With Volumetric Feature Alignment for Brain Tumor and Tissue Segmentation 一种用于脑肿瘤和组织分割的具有体积特征对齐的三维跨模态特征交互网络背景贡献实验方法Cross-Modality Feature Interaction ModuleVolumetric …

UE 程序化网格 计算横截面 面积

首先在构造函数内加上程序化网格&#xff0c;然后复制网格体到程序化网格组件上&#xff0c;将Static Mesh&#xff08;类型StaticMeshActor&#xff09;的静态网格体组件给到程序化网格体上 然后把StaticMesh&#xff08;类型为StaticMeshActor&#xff09;Instance暴漏出去 …

Apache Hive源码阅读环境搭建

前置软件&#xff1a; JDK 1.8 Maven 3.3.9 1 下载源码 # 下载源码 git clone https://github.com/apache/hive.gitcd hive# 查看标签 git tag# 切换到要阅读的指定版本的tag git checkout rel/release-2.1.02 编译源码 mvn clean install -DskipTests执行报错 日志如下 E…

C#,数值计算——插值和外推,曲线插值(Curve_interp)的计算方法与源程序

1 文本格式 using System; namespace Legalsoft.Truffer { /// <summary> /// Object for interpolating a curve specified by n points in dim dimensions. /// </summary> public class Curve_interp { private int dim { get; s…

消息积压了如何处理?

欢迎大家到我的博客阅读这篇文章。消息积压了如何处理&#xff1f; - 胤凯 (oyto.github.io)在系统中使用消息队列的时候&#xff0c;消息积压这个问题也经常遇到&#xff0c;并且这个问题还不太好解决。 消息积压的直接原因通常是&#xff0c;系统中的某个部分出现了性能问题…

初刷leetcode题目(2)——数据结构与算法

&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️Take your time ! &#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️&#x1f636;‍&#x1f32b;️…

YOLO目标检测——无人机检测数据集下载分享【含对应voc、coco和yolo三种格式标签】

实际项目应用&#xff1a;无人机识别数据集说明&#xff1a;无人机检测数据集&#xff0c;真实场景的高质量图片数据&#xff0c;数据场景丰富标签说明&#xff1a;使用lableimg标注软件标注&#xff0c;标注框质量高&#xff0c;含voc(xml)、coco(json)和yolo(txt)三种格式标签…

【Web】PHP反序列化的一些trick

目录 ①__wakeup绕过 ②加号绕过正则匹配 ③引用绕过相等 ④16进制绕过关键词过滤 ⑤Exception绕过 ⑥字符串逃逸 要中期考试乐(悲) ①__wakeup绕过 反序列化字符串中表示属性数量的值 大于 大括号内实际属性的数量时&#xff0c;wakeup方法会被绕过 &#xff08;php5-p…

基于海洋捕食者算法优化概率神经网络PNN的分类预测 - 附代码

基于海洋捕食者算法优化概率神经网络PNN的分类预测 - 附代码 文章目录 基于海洋捕食者算法优化概率神经网络PNN的分类预测 - 附代码1.PNN网络概述2.变压器故障诊街系统相关背景2.1 模型建立 3.基于海洋捕食者优化的PNN网络5.测试结果6.参考文献7.Matlab代码 摘要&#xff1a;针…

SQL零基础入门教程,贼拉详细!贼拉简单! 速通数据库期末考!(八)

FULL OUTER JOIN 除了前面讲到的 INNER JOIN&#xff08;内连接&#xff09;、LEFT JOIN&#xff08;左连接&#xff09;、RIGHT JOIN&#xff08;右连接&#xff09;&#xff0c;还有另外一种关联方式&#xff0c;即 FULL OUTER JOIN&#xff08;全外连接&#xff09; FULL O…

移动端路径传参以数字的形式,写死的情况

页面1 async getListTransferAndApprova() { //把mark值拼接到路径的后面&#xff0c;定义一个变量&#xff0c;使得切换穿的mark都不一样let mark ;if (this.tabsCurrent 0) {mark 2;} else if (this.tabsCurrent 1) {mark 3;}else if (this.tabsCurrent 2) {mark 4;}…

【AD封装】芯片IC-SOP,SOIC,SSOP,TSSOP,SOT(带3D)

包含了我们平时常用的芯片IC封装&#xff0c;包含SOP,SOIC,SSOP,TSSOP,SOT&#xff0c;总共171种封装及精美3D模型。完全能满足日常设计使用。每个封装都搭配了精美的3D模型哦。 ❖ TSSOP和SSOP 均为SOP衍生出来的封装。TSSOP的中文解释为&#xff1a;薄的缩小型 SOP封装。SSO…