YCKCOJ清明进阶专题题解

2024-04-06 21:12

本文主要是介绍YCKCOJ清明进阶专题题解,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

总的来说还是有难度的,这也能二分???
本套题需要大家尽量思考

A题 DARLING in the FRANXX
实际上这是一部好看的日漫,本题的背景主要以 叫龙 叫龙 叫龙为主,它是一种生物。。。好了言归正传,抓住核心题意: 02只想一次性清理掉某一级别的叫龙,所以不难发现最终我们环的排列方式一定是所有的A B C分别连成一块,例如AAAABBBBBCCCCC这样子。

对于环的问题,我们要固定一个点,这样子思维才不会被环的特殊性所迷惑(因为是环所以无法区分首尾),假设我们以1位置作为环的开头。

实际上最终02消灭叫龙的时候无外乎消除顺序是ABC的几种排列:
A B C ABC ABC
A C B ACB ACB
B A C BAC BAC
B C A BCA BCA
C A B CAB CAB
C B A CBA CBA
我们就按六种方式依次枚举,当然需要借助到一个快速统计的工具
以最终排列 A B C ABC ABC为例子,先统计一开始分别有 A , B , C A,B,C A,B,C种类的叫龙个数,如果以 A A A开头,那么由于环的性质,我们可以在开头摆放若干个 A A A叫龙,结尾摆放剩余叫龙,假如说 A A A叫龙一共有 a a a只,那么我们可以摆放0~a只叫龙在首,剩余在尾,这个可以枚举。然后摆放所有的 B B B叫龙与 C C C叫龙。但是我们需要知道一个数据: 把某种叫龙全部填在某个区间需要的引导次数 把某种叫龙全部填在某个区间需要的引导次数 把某种叫龙全部填在某个区间需要的引导次数
这个东西可以用前缀和实现,定义前缀和 A [ i ] A[i] A[i] 1 1 1 i i i位置内非 A 叫龙 A叫龙 A叫龙的个数,假如说我们现在要把 a a a A A A叫龙全部引导在一个长度为 a a a的区间 [ L , R ] [L,R] [L,R],那么求法就是 A [ R ] − A [ L − 1 ] A[R]-A[L-1] A[R]A[L1],直接计算区间内有多少个不是 A A A龙,然后引导即可,当然还要一种特殊的情况,那就是环,如果是环的话则是由开头一段+结尾一段来计算引导数,详情请看代码。

前缀和记录好以后,枚举第2个字母摆放位置,然后前缀和计算。
为什么枚举第2个字母的摆放位置呢?
实际上就是在考虑从首位置开始,摆放多少只第1个字母对应的叫龙,例如A叫龙一共a只,那么我可以在首位置开始摆放0~a只,那么第2个字母摆放的位置只能是1 ~ a+1

#include <bits/stdc++.h>
using namespace std;
const int maxn = 1e5 + 50;
int A[maxn], B[maxn], C[maxn];
char s[maxn];
int num[3];
int main()
{std::ios::sync_with_stdio(false);int n;cin >> n;cin >> s + 1;int a = 0, b = 0, c = 0;for(int i = 1;i <= n;i++){if(s[i] != 'A') A[i] = A[i - 1] + 1;else A[i] = A[i - 1], a++;if(s[i] != 'B') B[i] = B[i - 1] + 1;else B[i] = B[i - 1], b++;if(s[i] != 'C') C[i] = C[i - 1] + 1;else C[i] = C[i - 1], c++;}int ans = 1e9;for(int i = 1;i <= c + 1;i++)//AB{int cost = A[i + a - 1] - A[i - 1] + B[i + a + b - 1] - B[i + a - 1];cost += C[i - 1] + C[n] - C[i + a + b - 1];ans = min(cost, ans);}for(int i = 1;i <= c + 1;i++)//BA{int cost = B[i + b - 1] - B[i - 1] + A[i + a + b - 1] - A[i + b - 1];cost += C[i - 1] + C[n] - C[i + a + b - 1];ans = min(cost, ans);}for(int i = 1;i <= b + 1;i++)//AC{int cost = A[i + a - 1] - A[i - 1] + C[i + a + c - 1] - C[i + a - 1];cost += B[i - 1] + B[n] - B[i + c + a - 1];ans = min(cost, ans);}for(int i = 1;i <= b + 1;i++)//CA{int cost = C[i + c - 1] - C[i - 1] + A[i + c + a - 1] - A[i + c - 1];cost += B[i - 1] + B[n] - B[i + c + a - 1];ans = min(cost, ans);}for(int i = 1;i <= a + 1;i++)//BC{int cost = B[i + b - 1] - B[i - 1] + C[i + c + b - 1] - C[i + b - 1];cost += A[i - 1] + A[n] - A[i + c + b - 1];ans = min(cost, ans);}for(int i = 1;i <= a + 1;i++)//CB{int cost = C[i + c - 1] - C[i - 1] + B[i + c + b - 1] - B[i + c - 1];cost += A[i - 1] + A[n] - A[i + c + b - 1];ans = min(cost, ans);}cout << ans << endl;return 0;
}

这篇关于YCKCOJ清明进阶专题题解的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/880840

相关文章

Spring Boot + MyBatis Plus 高效开发实战从入门到进阶优化(推荐)

《SpringBoot+MyBatisPlus高效开发实战从入门到进阶优化(推荐)》本文将详细介绍SpringBoot+MyBatisPlus的完整开发流程,并深入剖析分页查询、批量操作、动... 目录Spring Boot + MyBATis Plus 高效开发实战:从入门到进阶优化1. MyBatis

Java进阶学习之如何开启远程调式

《Java进阶学习之如何开启远程调式》Java开发中的远程调试是一项至关重要的技能,特别是在处理生产环境的问题或者协作开发时,:本文主要介绍Java进阶学习之如何开启远程调式的相关资料,需要的朋友... 目录概述Java远程调试的开启与底层原理开启Java远程调试底层原理JVM参数总结&nbsMbKKXJx

MySQL进阶之路索引失效的11种情况详析

《MySQL进阶之路索引失效的11种情况详析》:本文主要介绍MySQL查询优化中的11种常见情况,包括索引的使用和优化策略,通过这些策略,开发者可以显著提升查询性能,需要的朋友可以参考下... 目录前言图示1. 使用不等式操作符(!=, <, >)2. 使用 OR 连接多个条件3. 对索引字段进行计算操作4

JavaScript中的reduce方法执行过程、使用场景及进阶用法

《JavaScript中的reduce方法执行过程、使用场景及进阶用法》:本文主要介绍JavaScript中的reduce方法执行过程、使用场景及进阶用法的相关资料,reduce是JavaScri... 目录1. 什么是reduce2. reduce语法2.1 语法2.2 参数说明3. reduce执行过程

Python进阶之Excel基本操作介绍

《Python进阶之Excel基本操作介绍》在现实中,很多工作都需要与数据打交道,Excel作为常用的数据处理工具,一直备受人们的青睐,本文主要为大家介绍了一些Python中Excel的基本操作,希望... 目录概述写入使用 xlwt使用 XlsxWriter读取修改概述在现实中,很多工作都需要与数据打交

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java进阶13讲__第12讲_1/2

多线程、线程池 1.  线程概念 1.1  什么是线程 1.2  线程的好处 2.   创建线程的三种方式 注意事项 2.1  继承Thread类 2.1.1 认识  2.1.2  编码实现  package cn.hdc.oop10.Thread;import org.slf4j.Logger;import org.slf4j.LoggerFactory

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

[MySQL表的增删改查-进阶]

🌈个人主页:努力学编程’ ⛅个人推荐: c语言从初阶到进阶 JavaEE详解 数据结构 ⚡学好数据结构,刷题刻不容缓:点击一起刷题 🌙心灵鸡汤:总有人要赢,为什么不能是我呢 💻💻💻数据库约束 🔭🔭🔭约束类型 not null: 指示某列不能存储 NULL 值unique: 保证某列的每行必须有唯一的值default: 规定没有给列赋值时的默认值.primary key:

【Linux 从基础到进阶】Ansible自动化运维工具使用

Ansible自动化运维工具使用 Ansible 是一款开源的自动化运维工具,采用无代理架构(agentless),基于 SSH 连接进行管理,具有简单易用、灵活强大、可扩展性高等特点。它广泛用于服务器管理、应用部署、配置管理等任务。本文将介绍 Ansible 的安装、基本使用方法及一些实际运维场景中的应用,旨在帮助运维人员快速上手并熟练运用 Ansible。 1. Ansible的核心概念