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 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的核心概念

Flutter 进阶:绘制加载动画

绘制加载动画:由小圆组成的大圆 1. 定义 LoadingScreen 类2. 实现 _LoadingScreenState 类3. 定义 LoadingPainter 类4. 总结 实现加载动画 我们需要定义两个类:LoadingScreen 和 LoadingPainter。LoadingScreen 负责控制动画的状态,而 LoadingPainter 则负责绘制动画。

C++ | Leetcode C++题解之第393题UTF-8编码验证

题目: 题解: class Solution {public:static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num &

从0到1,AI我来了- (7)AI应用-ComfyUI-II(进阶)

上篇comfyUI 入门 ,了解了TA是个啥,这篇,我们通过ComfyUI 及其相关Lora 模型,生成一些更惊艳的图片。这篇主要了解这些内容:         1、哪里获取模型?         2、实践如何画一个美女?         3、附录:               1)相关SD(稳定扩散模型的组成部分)               2)模型放置目录(重要)

C语言 | Leetcode C语言题解之第393题UTF-8编码验证

题目: 题解: static const int MASK1 = 1 << 7;static const int MASK2 = (1 << 7) + (1 << 6);bool isValid(int num) {return (num & MASK2) == MASK1;}int getBytes(int num) {if ((num & MASK1) == 0) {return

java学习,进阶,提升

http://how2j.cn/k/hutool/hutool-brief/1930.html?p=73689