【持续更新】2024牛客寒假算法基础集训营4 题解 | JorbanS

本文主要是介绍【持续更新】2024牛客寒假算法基础集训营4 题解 | JorbanS,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

A - 柠檬可乐

string solve() {int a, b, k; cin >> a >> b >> k;return a >= k * b ? "good" : "bad";
}

B - 左右互博

每次将一堆石子分成两堆,必然最后结果会多一个 1 1 1,因此只要看能多几个 1 1 1,即为可以操作的次数

string solve() {cin >> n;ll sum = 0;for (int i = 0; i < n; i ++) cin >> a[i], sum += a[i];return sum - n & 1 ? "gui" : "sweet";
}

C - 冬眠

暴力模拟

char solve() {cin >> n >> m >> x >> y;for (int i = 0; i < n; i ++) cin >> s[i];cin >> p >> q;for (int i = 0; i < q; i ++) {cin >> e[i].aa >> e[i].bb;e[i].bb --;}while (p --) {for (int i = 0; i < q; i ++) {if (e[i].aa == 1) {char c = s[e[i].bb][m - 1];for (int j = m - 1; j; j --) s[e[i].bb][j] = s[e[i].bb][j - 1];s[e[i].bb][0] = c;} else {char c = s[n - 1][e[i].bb];for (int j = n - 1; j; j --) s[j][e[i].bb] = s[j - 1][e[i].bb];s[0][e[i].bb] = c;}}}return s[-- x][-- y];
}

D - 守恒

重新分配数,由于 g c d × k = s u m , k ≥ n gcd\times k=sum,~k\ge n gcd×k=sum, kn,故 g c d ∣ n gcd|n gcdn

注意特判 n = 1 n=1 n=1

ll solve() {cin >> n;ll sum = 0, res = 0;for (int i = 0; i < n; i ++) cin >> a[i], sum += a[i];for (int i = 1; i <= sum / n; i ++)if (sum % i == 0) res ++;if (n == 1) return 1;return res;
}	

E - 漂亮数组

只许看前缀和相同的区间点,每次找到后 c l e a r clear clear 前面的已经被选择过的

int solve() {cin >> n >> k;int idx = 0;map<int, int> mp;for (int i = 1; i <= n; i ++) {cin >> a[i];a[i] += a[i - 1];a[i] %= k;}set<int> s;s.insert(0);int res = 0;for (int i = 1; i <= n; i ++) {if (s.count(a[i])) {res ++;s.clear();}s.insert(a[i]);}return res;
}

F - 来点每日一题


G - 数三角形(easy)

前缀和查询底边是否存在,总复杂度 O ( n 3 ) O(n^3) O(n3)

ll solve() {cin >> n >> m;for (int i = 0; i < n; i ++) cin >> s[i];for (int i = 0; i < n; i ++)for (int j = 0; j < m; j ++)a[i][j + 1] = a[i][j] + (s[i][j] == '*');ll res = 0;for (int i = 0; i < n; i ++)for (int j = 1; j < m - 1; j ++) {if (s[i][j] == '.') continue;for (int k = 1; k <= min(j, min(m - 1 - j, n - 1 - i)); k ++) {if (s[i + k][j - k] == '*' && s[i + k][j + k] == '*') {if (a[i + k][j + k + 1] - a[i + k][j - k] >= k * 2 + 1) res ++;} else break;}}return res;
}

这篇关于【持续更新】2024牛客寒假算法基础集训营4 题解 | JorbanS的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



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

相关文章

从基础到进阶详解Pandas时间数据处理指南

《从基础到进阶详解Pandas时间数据处理指南》Pandas构建了完整的时间数据处理生态,核心由四个基础类构成,Timestamp,DatetimeIndex,Period和Timedelta,下面我... 目录1. 时间数据类型与基础操作1.1 核心时间对象体系1.2 时间数据生成技巧2. 时间索引与数据

安装centos8设置基础软件仓库时出错的解决方案

《安装centos8设置基础软件仓库时出错的解决方案》:本文主要介绍安装centos8设置基础软件仓库时出错的解决方案,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录安装Centos8设置基础软件仓库时出错版本 8版本 8.2.200android4版本 javas

Linux基础命令@grep、wc、管道符的使用详解

《Linux基础命令@grep、wc、管道符的使用详解》:本文主要介绍Linux基础命令@grep、wc、管道符的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐... 目录grep概念语法作用演示一演示二演示三,带选项 -nwc概念语法作用wc,不带选项-c,统计字节数-

python操作redis基础

《python操作redis基础》Redis(RemoteDictionaryServer)是一个开源的、基于内存的键值对(Key-Value)存储系统,它通常用作数据库、缓存和消息代理,这篇文章... 目录1. Redis 简介2. 前提条件3. 安装 python Redis 客户端库4. 连接到 Re

SpringBoot基础框架详解

《SpringBoot基础框架详解》SpringBoot开发目的是为了简化Spring应用的创建、运行、调试和部署等,使用SpringBoot可以不用或者只需要很少的Spring配置就可以让企业项目快... 目录SpringBoot基础 – 框架介绍1.SpringBoot介绍1.1 概述1.2 核心功能2

使用雪花算法产生id导致前端精度缺失问题解决方案

《使用雪花算法产生id导致前端精度缺失问题解决方案》雪花算法由Twitter提出,设计目的是生成唯一的、递增的ID,下面:本文主要介绍使用雪花算法产生id导致前端精度缺失问题的解决方案,文中通过代... 目录一、问题根源二、解决方案1. 全局配置Jackson序列化规则2. 实体类必须使用Long封装类3.

Spring Boot集成SLF4j从基础到高级实践(最新推荐)

《SpringBoot集成SLF4j从基础到高级实践(最新推荐)》SLF4j(SimpleLoggingFacadeforJava)是一个日志门面(Facade),不是具体的日志实现,这篇文章主要介... 目录一、日志框架概述与SLF4j简介1.1 为什么需要日志框架1.2 主流日志框架对比1.3 SLF4

Spring Boot集成Logback终极指南之从基础到高级配置实战指南

《SpringBoot集成Logback终极指南之从基础到高级配置实战指南》Logback是一个可靠、通用且快速的Java日志框架,作为Log4j的继承者,由Log4j创始人设计,:本文主要介绍... 目录一、Logback简介与Spring Boot集成基础1.1 Logback是什么?1.2 Sprin

Oracle 通过 ROWID 批量更新表的方法

《Oracle通过ROWID批量更新表的方法》在Oracle数据库中,使用ROWID进行批量更新是一种高效的更新方法,因为它直接定位到物理行位置,避免了通过索引查找的开销,下面给大家介绍Orac... 目录oracle 通过 ROWID 批量更新表ROWID 基本概念性能优化建议性能UoTrFPH优化建议注

Springboot实现推荐系统的协同过滤算法

《Springboot实现推荐系统的协同过滤算法》协同过滤算法是一种在推荐系统中广泛使用的算法,用于预测用户对物品(如商品、电影、音乐等)的偏好,从而实现个性化推荐,下面给大家介绍Springboot... 目录前言基本原理 算法分类 计算方法应用场景 代码实现 前言协同过滤算法(Collaborativ