Codeforces Round 929 (Div. 3)

news2024/11/17 9:50:18

在这里插入图片描述

Codeforces Round 929 (Div. 3)

Codeforces Round 929 (Div. 3)

A. Turtle Puzzle: Rearrange and Negate

题意:可以对整数数组进行两个操作,一是随意重新排列或保持不变,二是选择连续子段元素符号倒转,求可能最大的所有元素和。

思路:所有元素的绝对值和。

AC code:

void solve() {
    int sum = 0;
    cin >> n;
    for (int i = 0; i < n; i ++) {
        int x; cin >> x;
        sum += abs(x);
    }
    cout << sum << endl;
}

B. Turtle Math: Fast Three Task

题意:给出整数数组a,可以选择任意两种操作,一是选择一个元素从数组a中删除,二是选择一个元素数值增加1;最少需要多少次操作可以使得数组元素之和能被3整除。

思路:

  • 元素和本来就能被3整除,0次操作;
  • 元素和mod3=2,1次添加操作;
  • 元素和mod3=1,若存在删除数组中的一个元素使得元素和被3整除,则1次操作,否则2次添加操作。

AC code:

void solve() {
    cin >> n;
    int sum = 0;
    for (int i = 0; i < n; i ++) {
        cin >> a[i];
        sum += a[i];
    }
    if (sum % 3 == 0) {
        cout << 0 << endl;
        return;
    }
    int u = sum % 3;
    if (u == 2) {
        cout << 1 << endl;
        return;
    }
    for (int i = 0; i < n; i ++) {
        if ((sum - a[i]) % 3 == 0) {
            cout << 1 << endl;
            return;
        }
    }
    cout << 2 << endl;
}

C. Turtle Fingers: Count the Values of k

题意:给出正整数a, b, l,若存在 k k k, x x x, y y y 使得 l = k ⋅ a x ⋅ b y l = k \cdot a^x \cdot b^y l=kaxby,则k有多少种不同的可能。

思路:暴力枚举x,y,注意处理枚举边界,即处理出x和y的最大可能再进行枚举。

AC code:

int tmp(int l, int t) {
    int pos = 0;
    while (l % t == 0) {
        l /= t;
        pos ++;
    }
    return pos;
}
 
void solve() {
    int a, b, l; cin >> a >> b >> l;
    int cnt = 0;
    map<int, int> mp;
    int A = tmp(l, a);
    int B = tmp(l, b);
    //cout << A << " " << B <<"+++" << endl;
    for (int i = 0; i <= A; i ++) {
        for (int j = 0; j <= B; j ++) {
            int t = pow(a, i) * pow(b, j);
            if (l % t == 0) {
                mp[l / t]++;
            }
        }
    }
    cout << mp.size() << endl;
}

D. Turtle Tenacity: Continual Mods

题意:给定正整数数组a,重排后得到数组b,是否可能存在 b 1   m o d   b 2   m o d   …   m o d   b n ≠ 0 b_1 \bmod b_2 \bmod \ldots \bmod b_n \neq 0 b1modb2modmodbn=0.

思路:找出所有元素的最小公倍数gcd,若存在题述情况,则gcd出现次数一定小于2,否则mod过程中会出现0.

AC code:

int gcd(int a, int b) {
    if (b) while ((a%=b) && (b%=a));
    return a + b;
}
 
void solve() {
    cin >> n;
    int now = -1;
    for (int i = 1; i <= n; i ++) {
        cin >> a[i];
        if (now == -1) {
            now = a[i];
        } else {
            now = gcd(now, a[i]);
        }
    }
    int cnt = 0;
    for (int i = 1; i <= n; i ++) {
        if (a[i] == now) cnt ++;
    }
    if (cnt < 2) {
        cout << "YES" << endl;
    } else {
        cout << "NO" << endl;
    }
}

E. Turtle vs. Rabbit Race: Optimal Trainings

题意:有n条跑道,每条跑道有 a i a_i ai个部分,给定一个正整数u,每完成一个部分成绩提高u,然后u-1,给出q组l和u,找出一个下标r,使得[l,r]的跑道成绩最高。

思路:二分找到最接近u的区间即可,注意二分的上边界和下边界都有可能成为答案,找到上下最接近u的边界,然后取其中离u最近的部分。

AC code:

void solve() {
    cin >> n;
    for (int i = 0; i <= n; i ++) {
        sum[i] = 0;
    }
    for (int i = 1; i <= n; i ++) {
        cin >> a[i];
        sum[i] = sum[i - 1] + a[i];
    }
    cin >> q;
    while (q --) {
        int l, u; cin >> l >> u;
        int L = l, R = n;
        while (L < R) {
            int mid = L + R + 1 >> 1;
            if (sum[mid] - sum[l - 1] <= u) L = mid;
            else R = mid - 1; 
        }
        int pos1 = L;
        L = l, R = n;
        while (L < R) {
            int mid = L + R >> 1;
            if (sum[mid] - sum[l - 1] >= u) R = mid;
            else L = mid + 1;
        }
        int pos2 = R;
        //cout << pos1 << " " << pos2 << "++++" << endl;
        int now1 = abs(sum[pos1] - sum[l - 1] - u), now2 = abs(sum[pos2] - sum[l - 1] - u);
        if (now1 >= now2) cout << pos2 << " ";
        else cout << pos1 << " "; 
    } cout << endl;
}

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

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

相关文章

nginx反向代理之缓存 客户端IP透传 负载均衡

一 缓存功能 缓存功能可以加速访问&#xff0c;如果没有缓存关闭后端服务器后&#xff0c;图片将无法访问&#xff0c;缓存功能默认关闭&#xff0c;需要开启。 相关选项&#xff1a; ​ proxy_cache zone_name | off; 默认off #指明调用的缓存&#xff0c;或关闭缓存机制;C…

opencv中两个LSD直线检测算法的区别与应用

opencv中两个LSD直线检测算法的区别与应用 同样是Line Segment Detector(lsd)算法&#xff0c;opencv中提供了两种实现&#xff0c;并且位于不同的模块。下面分别介绍它们的使用方法&#xff1a; 1. LineSegmentDetector 由于源码许可证问题 OpenCV 3.4.6-3.4.15、4.1.0-4.5.…

关于uniapp小程序的分包问题

开发uniapp小程序时&#xff0c;在打包上传代码时会出现超出2M的打包限制不能上传&#xff0c;那么我们该怎么做呢&#xff1f; 1.对于图片&#xff0c;将图片从后端服务取&#xff0c;尽量不要放在静态资源&#xff0c;图片体积会影响打包大小。 2.使用分包&#xff0c;tabb…

蓝桥杯_中断系统

一 中断 中断&#xff0c;即cpu暂停执行当前程序&#xff0c;转而执行另外一段特殊程序&#xff0c;处理结束后。返回之前暂停程序继续执行。 中断向量&#xff0c;中断服务程序的入口地址&#xff0c;每个中断源都对应一个固定的入口地址。 中断服务函数&#xff0c;内核响应中…

华为s5720s-28p-power-li-ac堆叠配置

叠物理约束&#xff1a; • 连线推荐示意图选用产品子系列中固定的一款设备做示例&#xff0c;与选择产品时指定型号的外观可能不同。示意图主要用于让用户了解相同子系列设备可以用作堆叠的端口的位置&#xff0c;以及使用不同的连线方式时如何连接设备上的端口。因此&#xf…

解决vscode内置视图npm脚本操作报权限问题

项目背景 当我们使用 vscode 运行NPM脚本时却爆红了&#xff0c;提示系统上禁止运行脚本。 解决思路 竟然提示权限不够&#xff0c;那么咱们就从系统权限出发&#xff0c;vscode右键以管理员身份运行 在集成终端中输入一下命令 # get-executionpolicy是PowerShell中的命令,用…

推荐5个python可视化库

你是否曾为数据可视化而烦恼&#xff1f; 在浩瀚的数据海洋中&#xff0c;如何将复杂的数据以直观、易懂的方式展现出来&#xff0c;成为了每个数据分析师和开发者必须面对的挑战。 幸运的是&#xff0c;我们有众多强大的可视化工具可以选择。 推荐5个Python可视化库&#x…

JS画摆线

最近看到一个很漂亮的曲线&#xff0c;研究了一下。 从圆心画一条线匀速转动&#xff0c;终点再画一条线转动&#xff0c;2条线转速不同&#xff0c;会画出很漂亮的花纹。 一个周期 完整周期 <html> <style> body { background:black; } p { text-align:center; c…

Spring中的事务和事务的传播机制

事务是一组操作的集合&#xff0c;不可以被分割。事务会把所有的操作作为一个整体&#xff0c;这组操作要么全部成功&#xff0c;要么全部失败。 事务有三种操作&#xff1a; 开启事务&#xff1b;提交事务&#xff1b;回滚事务。 如果代码的执行逻辑是这样&#xff1a; 开…

国际黄金价格是什么?和黄金价格有何区别?

黄金是世界上最珍贵的贵金属之一&#xff0c;其价值被无数人所垂涎。而国际黄金价格作为市场上的参考指标&#xff0c;直接影响着黄金交易的买卖。那么国际黄金价格到底是什么&#xff0c;与黄金价格又有何区别呢&#xff1f;本文将为您详细解答。 国际黄金价格是指以美元计量的…

【双碳】Acrel-1000DP分布式光伏并网及数据采集与控制的方式

摘要&#xff1a; 在“双碳”、整县分布式光伏等相关政策的目标背景下&#xff0c;分布式新能源广泛建设&#xff0c;对分布式新能 源规划的科学性提出更高的要求&#xff0c;有源配电网调度面临大规模分布式新能源参与后的运行管理问题&#xff0c;增 大了电网运行管理的风险和…

用友 NC 23处接口XML实体注入漏洞复现

0x01 产品简介 用友 NC 是用友网络科技股份有限公司开发的一款大型企业数字化平台。 0x02 漏洞概述 用友 NC 多处接口存在XML实体注入漏洞,未经身份验证攻击者可通过该漏洞读取系统重要文件(如数据库配置文件、系统配置文件)、数据库配置文件等等,导致网站处于极度不安全…

图搜索基础-深度优先搜索

图搜索基础-深度优先搜索 参考原理引入流程解析手推例子 代码实现运行结果结果分析 参考 理论参考&#xff1a;深蓝学院 实现参考&#xff1a;github项目 原理 引入 对于这样一个图&#xff0c;我们试图找到S到G的通路&#xff1a; 计算机程序不会像人眼一样&#xff0c;一…

事件驱动的奇迹:深入理解Netty中的EventLoop

欢迎来到我的博客&#xff0c;代码的世界里&#xff0c;每一行都是一个故事 事件驱动的奇迹&#xff1a;深入理解Netty中的EventLoop 前言基础概念EventLoop的工作原理Channel与EventLoop的关系定时任务与延时任务EventLoop的生命周期EventLoop中的线程模型性能优化与最佳实践 …

前后端依赖下载上传

在某些情况下&#xff0c;可能需要在没有互联网连接的环境中进行构建或部署。通过提前下载所有依赖&#xff0c;你可以将它们保存在本地&#xff0c;然后在没有网络连接时使用&#xff0c;提高构建或部署的效率。 前端下载依赖 脚本getTzgUrl.js const { readFileSync, writ…

前端架构: 脚手架之包管理工具的案例对比及workspace特性的基本使用

Npm WorkSpace 特性 1 &#xff09;使用或不使用包管理工具的对比 vue-cli 这个脚手架使用 Lerna 管理&#xff0c;它的项目显得非常清晰在 vue-cli 中包含很多 package 点开进去&#xff0c;每一个包都有package.json它里面有很多项目&#xff0c;再没有 Lerna 之前去维护和管…

sql | leecode 1147 |即时事务配送II | sql 优化

sql 有时候还是挺有意思的&#xff0c;有时候不只是crud 下面来看一道sql 题&#xff0c;第一个题解能跑完&#xff0c;但是超时 浮躁的人总是很难看的进去&#xff0c;有时候孤单又在所难免&#xff0c;所以啊 要继续坚持&#xff0c;原来中学老师讲的那句&#xff0c;要耐住寂…

arm服务器上部署kibana

1.首先需要从elasticsearch对应的kibana版本(arm) ​​​​​​Download Kibana Free | Get Started Now | Elastic 注意:选平台时切勿选错,linux aarch64,并选择elasticsearch对应的历史版本 2.可以通过rz命令上传压缩包至 linux 服务器进行解压&#xff0c;存放路径建议和e…

物联网通信协议介绍

为了方便&#xff0c;将物联网通信协议分为两大类&#xff0c;一类是接入协议&#xff0c;一类是通讯协议。接入协议一般负责子网内设备间的组网及通信&#xff1b;通讯协议主要是运行在传统互联网TCP/IP协议之上的设备通讯协议&#xff0c;负责设备通过互联网进行数据交换及通…

数据结构:排序算法+查找算法

一、概念 程序数据结构算法 1.算法的特性和要求 特性&#xff1a; 确定性&#xff08;每次运行相同的输入都是同样的结果&#xff09;、有穷性、输入、输出、可行性 设计要求&#xff1a; 正确性、高效率、低存储、健壮性、可读性 2.时间复杂度 3.常见排序算法的时间复杂…