Codeforces Round 916 (Div. 3)

在这里插入图片描述

Codeforces Round 916 (Div. 3)

A. Problemsolving Log

题意:竞赛中有26个问题需要解决,每个问题名称为A到Z26个英文字母,按难度排序,做出A需要花费1分钟,B需要花费2分钟…以此类推。现在给出一个字符串表示竞赛日志,第i个字符表示第i分钟在某个题上花费的时间,求解决问题的数量。

思路:记录每个题花费的总时间,只要不小于解决该题需要花费的时间就能解决该问题。

AC code:

void solve(){
    mp.clear();
    cin >> n >> s;
    for(char c : s) mp[c] ++;
    int ans = 0;
    for(char i = 'A'; i <= 'Z'; i ++){
        if(mp[i] >= i - 'A' + 1) ans ++;
    }cout << ans << endl;
}

B. Preparing for the Contest

题意:现在需要解决1到n共n个难度的问题,当前解决的问题比前一个问题难时会兴奋,现需要兴奋k次,给出可能的解决问题的顺序。

思路:选出k+1个数从小到大排列,然后剩下的数从大到小排列即可。

AC code:

void solve(){
    cin >> n >> k;
    for(int i = n - k; i <= n; i ++)
        cout << i << " ";
    for(int i = n - k - 1; i >= 1; i --)
        cout << i << " ";
    cout << endl;
}

C. Quests

题意:为了尽可能提升游戏角色的经验值,游戏中有1~n个任务。当序号小的任务全部完成时就能完成后面的新任务,每个任务第一次完成会获得经验值 a i a_i ai,重复完成任务会获得经验值 b i b_i bi。现在最多完成k次任务,最多获得多少经验值。

思路:前缀和第一次完成任务的经验值,因为开启后面的任务必定会完成前面的任务,从前向后枚举最多开启到当前任务时,重复经验价值最大的任务,取最大值。

AC code:

void solve(){
    cin >> n >> k;
    a[0] = 0, sum[0] = 0;
    for(int i = 1; i <= n; i ++){
        cin >> a[i];
        sum[i] = sum[i - 1] + a[i];
    }
    for(int i = 1; i <= n; i ++)
        cin >> b[i];
    int ans = 0, now = 0;
    for(int i = 1; i <= n; i ++){
        if(i > k) break;
        now = max(now, b[i]);
        ans = max(ans, sum[i] + (k - i) * now);
    }
    cout << ans << endl;
}

D. Three Activities

题意:给出三个长度为n的序列,每个序列找一个数,且下标不能相同,三数的和最大。

思路:开三个pair同时记录数值与下标,然后降序排序,枚举每个序列最大的前三个数即可。

AC code:

PII a[N], b[N], c[N];
 
bool cmp(PII a, PII b){
    return a.first > b.first;
}
 
void solve(){
    cin >> n;
    for(int i = 1; i <= n; i ++){
        int x; cin >> x;
        a[i] = {x, i};
    }
    for(int i = 1; i <= n; i ++){
        int x; cin >> x;
        b[i] = {x, i};
    }
    for(int i = 1; i <= n; i ++){
        int x; cin >> x;
        c[i] = {x, i};
    }
    sort(a + 1, a + n + 1, cmp);
    sort(b + 1, b + n + 1, cmp);
    sort(c + 1, c + n + 1, cmp);
    int ans = 0;
    for(int x = 1; x <= 3; x ++){
        for(int y = 1; y <= 3; y ++){
            for(int z = 1; z <= 3; z ++){
                if(a[x].second != b[y].second && a[x].second != c[z].second && b[y].second != c[z].second)
                    ans = max(ans, a[x].first + b[y].first + c[z].first);
            }
        }
    }cout << ans << endl;
}

E. Game with Marbles

题意:A和B各有n种不同颜色的弹珠,每种颜色弹珠分别有 a i a_i ai b i b_i bi个,游戏规则如下:

两人轮流,A先开始,轮到自己时选择一种颜色i,若两个玩家都至少有一个,那么自己丢弃一颗该颜色的弹珠,另一个玩家丢弃所有该颜色的弹珠,当没有一种颜色的弹珠双方均至少有一颗时游戏结束。

游戏得分为A剩余弹珠数量减去B剩余弹珠数量,A需要最大化分数,B需要最小化分数。

双方最佳发挥,计算最终得分。

思路:博弈,A和B的最终目的均为最大化自己剩余的弹珠以及最小化对方剩余的弹珠,对于某一种颜色的弹珠,在双方都至少有一颗的情况下,当轮到自己的回合时都是自己丢弃一颗弹珠,清空对方弹珠为最佳,而优先选择攻击的弹珠即为a+b当前数量最大颜色的弹珠,最小化对方留存弹珠,最大化自身留存弹珠。

所以A和B轮流对当前双方留存弹珠和最大的颜色弹珠进行选择即为最优。

AC code:

PII p[N];
 
bool cmp(PII a, PII b){
    return a.first + a.second > b.first + b.second;
}
 
void solve(){
    cin >> n;
    for(int i = 1; i <= n; i ++) cin >> p[i].first;
    for(int i = 1; i <= n; i ++) cin >> p[i].second;
    sort(p + 1, p + n + 1, cmp);
    int ans = 0;
    for(int i = 1; i <= n; i ++){
        if(i % 2) ans += (p[i].first - 1);
        else ans -= (p[i].second - 1);
    }cout << ans << endl;
}

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

【SpringBoot快速入门】(4)SpringBoot项目案例代码示例

目录 1 创建工程3 配置文件4 静态资源 之前我们已经学习的Spring、SpringMVC、Mabatis、Maven&#xff0c;详细讲解了Spring、SpringMVC、Mabatis整合SSM的方案和案例&#xff0c;上一节我们学习了SpringBoot的开发步骤、工程构建方法以及工程的快速启动&#xff0c;从这一节开…

js禁止打开控制台,如何强行打开控制台?

当我在查看某个网站的源码时&#xff0c;按F12会跳转到百度页面&#xff0c;或者先打开F12再输入网站也会进入到百度首页。 首先我们要关闭控制台进入到这个网站的首页&#xff0c;然后右键查 看网站的源码。 1.找到这个js文件&#xff0c;点进去。 2.点击这个js文件之后&a…

mysql:查看服务端没有睡眠的线程数量

使用命令show global status like Threads_running;可以查看服务端没有睡眠的线程数量。 例如&#xff1a;

Open3D 最小二乘拟合平面(直接求解法)

目录 一、算法原理二、代码实现三、结果展示本文由CSDN点云侠原创,原文链接。爬虫自重。 一、算法原理 平面方程的一般表达式为: A x + B y + C z

108基于matlab的使用模拟退火 (SA) 求解并行机器调度的程序

基于matlab的使用模拟退火 &#xff08;SA&#xff09; 求解并行机器调度的程序&#xff0c;程序已调通&#xff0c;可直接运行。 108 matlab模拟退火 &#xff08;SA) (xiaohongshu.com)

革命性突破:Great River推出XL高速ARINC 818传感器测试卡

Great River Technology荣幸地宣布&#xff0c;与RVS&#xff08;远程视觉系统&#xff09;2.0平台合作推出的XL高速ARINC 818传感器测试卡正式亮相。这款开创性的测试卡在柯林斯航空电子公司&#xff08;RTX业务部&#xff09;和波音公司开发和测试RVS 2.0系统中发挥了重要作用…

动态内存分配

为什么存在内存开辟 我们掌握的内存开辟方式有 int val 20;//在栈空间上开辟四个字节 char arr[10] {0}&#xff1b;//在栈空间上开辟十个连续的内存空间 但是上述开辟空间的方式有两个特点&#xff1a;1.空间开辟大小是固定的。 2.数组在申明的时候&#xff0c;必须指明数…

LCR 183. 望远镜中最高的海拔

解题思路&#xff1a; class Solution {public int[] maxAltitude(int[] heights, int limit) {if(heights.length 0 || limit 0) return new int[0];Deque<Integer> deque new LinkedList<>();int[] res new int[heights.length - limit 1];// 未形成窗口for…

程序员的50大JVM面试问题及答案

文章目录 1.JDK、JRE、JVM关系&#xff1f;2.启动程序如何查看加载了哪些类&#xff0c;以及加载顺序&#xff1f;3. class字节码文件10个主要组成部分?4.画一下jvm内存结构图&#xff1f;5.程序计数器6.Java虚拟机栈7.本地方法栈8.Java堆9.方法区10.运行时常量池&#xff1f;…

Java---泛型讲解

文章目录 1. 泛型类2. 泛型方法3. 泛型接口4. 类型通配符5. 可变参数6. 可变参数的使用 1. 泛型类 1. 格式&#xff1a;修饰符 class 类名 <类型>{ }。例如&#xff1a;public class Generic <T>{ }。 2. 代码块举例&#xff1a; public class Generic <T>{…

【python】作用域与闭包 || global与nonlocal

python作用域 其他语言的作用域&#xff1a;块级、函数、类、模块、包等由小到大的级别但是python没有块级&#xff08;if语句块、for语句块&#xff09;&#xff0c;所以if中定义的变量&#xff0c;相当于普通语句 >>> if True: # if语句块没有作用域x …

【多模态对话】《颠覆性创新:多模态对话与精准区域分割 - VPGTrans NExT-Chat》学习笔记

【OpenMMLab社区开放麦讲座】《颠覆性创新&#xff1a;多模态对话与精准区域分割 - VPGTrans & NExT-Chat》 1 VPGTrans 1.1 研究问题 1.1.1 模态对齐预训练开销很大&#xff1a;训练时间长 解决方案&#xff1a;迁移已有的VPG(比如BLIP-2 OPT 27B上的VPG) 1.2 训练技巧…

kubernetes集群应用 service进阶

kubernetes集群应用 Service进阶 一、场景 使用kubernetes集群运行工作负载时&#xff0c;由于Pod经常处于用后即焚状态&#xff0c;Pod对应的IP地址也会经常变化&#xff0c;因此我们不能直接访问Pod&#xff0c;可以通过Service对应的端点列表&#xff08;Endpoints&#x…

文件夹数据同步工具 Sync Folders Pro mac支持选项

Sync Folders Pro for Mac 是一款功能强大的文件夹同步工具&#xff0c;旨在帮助用户在 Mac 计算机和移动设备之间创建双向同步。这款软件支持各种文件系统和设备&#xff0c;如 iPhone&#xff0c;iPad&#xff0c;iPod&#xff0c;Android 等。通过这款软件&#xff0c;用户可…

Vue.js 中使用 Element UI 实现异步加载分页列表

Vue.js 中使用 Element UI 实现异步加载分页列表 在前端开发中&#xff0c;我们常常需要展示大量数据&#xff0c;并提供分页浏览的功能。本篇博客将介绍如何使用 Vue.js 和 Element UI 组件库创建一个简单的异步加载分页列表。 技术栈 Vue.jsElement UIJavaScript 组件结构…

计算机存储术语: 扇区,磁盘块,页

扇区(sector) 硬盘的读写以扇区为基本单位。磁盘上的每个磁道被等分为若干个弧段&#xff0c;这些弧段称之为扇区。硬盘的物理读写以扇区为基本单位。通常情况下每个扇区的大小是 512 字节。linux 下可以使用 fdisk -l 了解扇区大小&#xff1a; $ sudo /sbin/fdisk -l Disk …

力扣日记12.21【二叉树篇】98. 验证二叉搜索树

力扣日记&#xff1a;【二叉树篇】98. 验证二叉搜索树 日期&#xff1a;2023.12.21 参考&#xff1a;代码随想录、力扣 98. 验证二叉搜索树 题目描述 难度&#xff1a;中等 给你一个二叉树的根节点 root &#xff0c;判断其是否是一个有效的二叉搜索树。 有效 二叉搜索树定义…

VLOOKUP中的#N/A错误很常见,这里有详细排除步骤

你的VLOOKUP是否提取了错误的数据&#xff0c;或者你根本无法使其工作&#xff1f;本教程展示了如何快速修复常见的VLOOKUP中的#N/A错误并克服其主要限制。 ​在VLOOKUP公式中&#xff0c;当Excel找不到查找值时&#xff0c;会显示#N/A错误消息&#xff08;意思是“不可用”&a…

目标检测入门体验,技术选型,加载数据集、构建机器学习模型、训练并评估

Hi, I’m Shendi 1、目标检测入门体验&#xff0c;技术选型&#xff0c;加载数据集、构建机器学习模型、训练并评估 在最近有了个物体识别的需求&#xff0c;于是开始学习 在一番比较与询问后&#xff0c;最终选择 TensorFlow。 对于编程语言&#xff0c;我比较偏向Java或nod…

冬至快乐Happy winter solstice

冬至通常是每年的12月21日到12月23日之间&#xff0c;在这一天&#xff0c;白昼时间是全年最短的一天&#xff0c;夜晚是全年时间最长的一天“Winter Solstice” falls between the periods of December 21 to December 23. On this day, the day is the shortest and night is…