Codeforces Pinely Round 3 (Div. 1 + Div. 2)

A.Distinct Buttons(思维)

题意:

你在开始时站在点 ( 0 , 0 ) (0,0) (0,0),同时,手上有一个遥控器,上面有四个按钮:

  • U:移动到 ( x , y + 1 ) (x, y + 1) (x,y+1)的位置

  • R:移动到 ( x + 1 , y ) (x + 1, y) (x+1,y)的位置

  • D:移动到 ( x , y − 1 ) (x, y - 1) (x,y1)的位置

  • L:移动到 ( x − 1 , y ) (x - 1, y) (x1,y)的位置

如果四个按钮都被按下过,那么遥控器将会被损坏,问能否到达给出的所有 n n n个点。

分析:

如果只能使用三个按键,那么只有在需要到达的所有点均在以下四个面中的一个时才能完成:

  • 所有点都在 x x x轴上方

  • 所有点都在 x x x轴下方

  • 所有点都在 y y y轴左侧

  • 所有点都在 y y y轴右侧

输入时使用数组记录出现的位置,最后判断输出即可。

代码:

#include<bits/stdc++.h>using namespace std;
typedef long long LL;
const int MAXN = 3e5 + 5e2;void solve() {int n;cin >> n;int a[5] = {0, 0, 0, 0};for (int i = 0; i < n; i++) {int x, y;cin >> x >> y;if (x > 0) {a[0] = 1;} else if (x < 0) {a[1] = 1;}if (y > 0) {a[2] = 1;} else if (y < 0) {a[3] = 1;}}if (a[0] + a[1] + a[2] + a[3] > 3) cout << "No" << endl;else cout << "Yes" << endl;
}int main() {int Case;cin >> Case;while (Case--) {solve();}return 0;
}

B.Make Almost Equal With Mod(思维)

题意:

给出一个数组 a 1 , a 2 , . . . , a n a_1, a_2, ..., a_n a1,a2,...,an,你可以选择一个数字 k k k,使数组中所有数字对 k k k取模,问 k k k等于多少时,可以使得数组中的数字再操作后恰好包含两种不同的数字。

分析:

依次枚举 2 2 2的次方数即可。

说明:

  • 选择 2 2 2作为 k k k时,剩下的结果仅包含 0 , 1 0, 1 0,1

  • 如果剩下的数字全部为 0 0 0 1 1 1,继续选择 2 2 = 4 2^2 = 4 22=4作为 k k k,若选择 2 2 2时剩下的数字为 0 0 0,那么选择 k = 4 k = 4 k=4时剩下的就是 0 , 2 0, 2 0,2,同理,剩下数字均为 1 1 1,则选择 k = 4 k = 4 k=4时剩下的数字就是 1 , 3 1, 3 1,3

  • 依次类推,由于每次取模的结果只会有两种可能性,那么当结果中两种情况均出现就找到了合法的 k k k

代码:

#include<bits/stdc++.h>using namespace std;
typedef long long LL;
const int MAXN = 3e5 + 5e2;LL a[MAXN];void solve() {int n;cin >> n;for (int i = 1; i <= n; i++) cin >> a[i];for (LL i = 2; ; i <<= 1) {set<LL> S;for (int j = 1; j <= n; j++) {S.insert(a[j] % i);if (S.size() > 2) break;}if (S.size() == 2) {cout << i << endl;return;}}
}int main() {int Case;cin >> Case;while (Case--) {solve();}return 0;
}

C.Heavy Intervals(思维)

题意:

给出 n n n个区间 [ l i , r i ] [l_i, r_i] [li,ri],每个区间包含一个权值 c i c_i ci,且区间的价值为: c i × ( r i − l i ) c_i \times (r_i - l_i) ci×(rili),你可以在保证区间合法 ( l i < r i ) (l_i < r_i) (li<ri)的情况下,对所有区间的 l i , r i , c i l_i, r_i, c_i li,ri,ci进行任意重排,问所有区间的价值之和最小是多少?

分析:

既然要让价值之和最小,那么大的权值 c i c_i ci就要与长度更小的区间匹配,那要怎么在保证区间合法的情况下,让构造的区间尽可能长呢?

可以使用类似括号匹配的思想,先对 l i l_i li r i r_i ri进行排序,把 l i l_i li r i r_i ri视为左右括号进行括号匹配,并将构造成的区间长度记录下来。

完成匹配后,对权值 c i c_i ci和构造的区间长度 l e n len len进行排序,并按最大的权值和最小的区间长度进行匹配,次大的权值和次小的区间长度进行匹配,依次类推,就能得到最小的价值之和。

代码:

#include<bits/stdc++.h>using namespace std;
typedef long long LL;
const int MAXN = 3e5 + 5e2;LL l[MAXN], r[MAXN], c[MAXN], len[MAXN];stack<int> st;void solve() {int n;cin >> n;for (int i = 0; i < n; i++) {cin >> l[i];}for (int i = 0; i < n; i++) {cin >> r[i];}for (int i = 0; i < n; i++) {cin >> c[i];}sort(l, l + n);sort(r, r + n);sort(c, c + n);int pos_l = 0, pos_r = 0, cnt = 0;for (int i = 0; i < n * 2; i++) {if (pos_l < n && pos_r < n) {if (l[pos_l] < r[pos_r]) {st.push(l[pos_l++]);} else {len[cnt++] = r[pos_r++] - st.top();st.pop();}} else {len[cnt++] = r[pos_r++] - st.top();st.pop();}}LL ans = 0;sort(len, len + n);for (int i = 0, j = n - 1; i < n; i++, j--) {ans += len[i] * c[j];}cout << ans << endl;
}int main() {int Case;cin >> Case;while (Case--) {solve();}return 0;
}

D.Split Plus K(思维)

题意:

给出 n n n个正整数 a 1 , a 2 , . . . , a n a_1, a_2, ..., a_n a1,a2,...,an,你可以进行若干次以下操作:

  • 选择一个数字 x x x,并将这个数字删除。

  • 选择两个正整数 y , z y, z y,z满足 y + z = x + k y + z = x + k y+z=x+k,并将这两个数字放回。

问:能否在经过若干次操作后,使数组中所有数字相同,如果可以,输出最少操作次数,否则,输出-1.

分析:

由于每次产生的两个数字 y , z y, z y,z的总和会比原本的数字 x x x k k k,因此,如果一个数字被分解了 m m m次,那么得到的 m + 1 m + 1 m+1个数字的总和就是 x + m × k x + m \times k x+m×k

b 0 , b 1 , . . . , b m b_0, b_1, ..., b_m b0,b1,...,bm为最后生成的 m + 1 m + 1 m+1个数字,由于分解时会增加 k k k,且会增加 m m m次,那么可以将 m m m k k k分配给 b 1 ∼ b m b_1 \sim b_m b1bm,即最后生成的数字为 b 0 , b 1 + k , b 2 + k , . . . , b m + k b_0, b_1 + k, b_2 + k, ..., b_m + k b0,b1+k,b2+k,...,bm+k

由题目可得以下两个式子:

  • b 0 = b 1 + k = . . . = b m + k b_0 = b_1 + k = ... = b_m + k b0=b1+k=...=bm+k

  • b 0 + b 1 + k + . . . + b m + k = a i + m × k b_0 + b_1 + k + ... + b_m + k = a_i + m \times k b0+b1+k+...+bm+k=ai+m×k

由于无法知道最后分解出的数字数量 m m m到底是多少,因此需要对式子进行化简,让第二个式子两边同时减去 m + 1 m + 1 m+1 k k k,可得:

  • ( b 0 − k ) + b 1 + . . . + b m = a i − k (b_0 - k) + b_1 + ... + b_m = a_i - k (b0k)+b1+...+bm=aik

而此时所有的 b 1 ∼ b m b_1 \sim b_m b1bm以及 b 0 − k b_0 - k b0k均为 a i − k a_i - k aik的因子,因此,可以在输入后,将所有 a i a_i ai均减去 k k k

然后,需要考虑,如果减去 k k k后的 a a a数组中出现了同时包含正负数或同时出现 0 0 0和其他数字,此时是无法完成构造的,直接输出 − 1 -1 1

最后考虑最后生成的数字,既然要让操作次数尽可能少,那么拆出的数字就要尽可能大,怎么选择最大的结果呢?只有选择减去 k k k之后的所有 a i − k a_i - k aik的最大公约数 G G G

由于每次操作会增加一个数字,因此,将 a i − k a_i - k aik分解为若干个 G G G所需的操作次数为 a i − k G − 1 \frac{a_i - k}{G} - 1 Gaik1

代码:

#include<bits/stdc++.h>using namespace std;
typedef long long LL;
const int MAXN = 3e5 + 5e2;LL n, k, a[MAXN];void solve() {cin >> n >> k;LL maxn = -1e18, minn = 1e18;for (int i = 1; i <= n; i++) cin >> a[i], a[i] -= k, maxn = max(maxn, a[i]), minn = min(minn, a[i]);if (maxn == minn) {cout << 0 << endl;return;}if (minn < 0 && maxn >= 0 || minn == 0 && maxn > 0) {cout << "-1" << endl;return;}LL g = a[1];for (int i = 2; i <= n; i++) g = __gcd(g, a[i]);LL ans = 0;for (int i = 1; i <= n; i++) {ans += a[i] / g - 1;}cout << ans << endl;
}int main() {int Case;cin >> Case;while (Case--) {solve();}return 0;
}

学习交流


以下为学习交流QQ群,群号: 546235402,每周题解完成后都会转发到群中,大家可以加群一起交流做题思路,分享做题技巧,欢迎大家的加入。

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

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

相关文章

代码随想录算法训练营Day10 | 239.滑动窗口的最大值、347.前K个高频元素

LeetCode 239 滑动窗口的最大值 本题思路: 采用单调队列来完成&#xff0c;单调队列就是队列里的元素顺序&#xff0c;是单调递减/递增的情况。 那么我们应该如何维护这个单调队列呢&#xff0c;此处既然是最大值&#xff0c;那么采用的是单调递减的队列。让队列的出口处是当前…

java爬虫(jsoup)如何设置HTTP代理ip爬数据

目录 前言 什么是HTTP代理IP 使用Jsoup设置HTTP代理IP的步骤 1. 导入Jsoup依赖 2. 创建HttpProxy类 3. 设置代理服务器 4. 使用Jsoup进行爬取 结论 前言 在Java中使用Jsoup进行网络爬虫操作时&#xff0c;有时需要使用HTTP代理IP来爬取数据。本文将介绍如何使用Jsoup设…

如何给beaglebone black狗板扩容

接上一篇 beaglebone black狗板&#xff0c;交叉编译Qt5&#xff08;eglfs&#xff09;-CSDN博客 默认的分区大小已经不够了&#xff0c;需要调整 这里改成500M&#xff0c;能勉强正常&#xff0c;但是SD是32G还是有大量的剩余空间没被使用 这里可以用以下两类方法来把剩余的…

电影分线发行来势汹汹,行业新规到底利好谁?

年末的贺岁档&#xff0c;一直是各大影视公司的必争之地&#xff0c;但2023年却透露出一股不寻常的气息。 在10月份举办的第一届全国电影交易大会上&#xff0c;分线发行影片的机制被提出之后&#xff0c;贺岁档的多部影片启用了这一发行方式。 分线发行&#xff0c;简单来说…

apisix 路由转发成功 但响应502异常(转发导致客户端来源发生变化)

访问报如下异常 这种情况通常是通过apisix转发后&#xff0c;导致丢失原有域名&#xff08;也可以理解为客户端来源变了&#xff09;导致最终程序端某些安全检查不通过 此时有两种解决方法 路由中修改 操作路径&#xff1a; 路由-域名改写 如下图 上游&#xff08;upstream…

Mac上5款非常实用的资源工具分享

Lifespan Lifespan是一款创新的macOS菜单栏应用程序&#xff0c;旨在监控基于闪存的存储设备的剩余使用寿命。我们的软件可以方便地显示您的固态硬盘 (SSD) 的剩余寿命。寿命菜单显示每个支持的SSD的当前寿命&#xff0c;并在剩余寿命接近临界阈值时立即向您发出警报。有了这些…

ZKTeco与亚马逊云科技部署Cloud Foundations解决方案,构建MinervaIoT高质量云底座

ZKTeco背景介绍 熵基科技股份有限公司&#xff08;ZKTeco&#xff09;成立于2007年&#xff0c;是一家多模态“计算机视觉与生物识别”领域的领军企业。熵基科技于2021年开始与亚马逊云科技合作&#xff0c;推进集团云转型&#xff0c;逐步将各产品线云化。其中最重要的里程碑是…

智慧城市新型基础设施建设综合方案:文件全文52页,附下载

关键词&#xff1a;智慧城市建设方案&#xff0c;智慧城市发展的前景和趋势&#xff0c;智慧城市项目方案&#xff0c;智慧城市管理平台&#xff0c;数字化城市&#xff0c;城市数字化转型 一、智慧城市新基建建设背景 1、城市化进程加速&#xff1a;随着城市化进程的加速&am…

K8s简述

1、定义&#xff1a;是一种开源的容器集群管理系统&#xff0c;在docker 容器技术的基础之上&#xff0c;为容器化的集群提供部署、运行、资源调度、服务发现、动态伸缩等一系列完整的功能的大规模容器管理 2、功能 &#xff08;1&#xff09;对docker的容器技术应用的包&…

RHCE9学习指南 第11章 网络配置

11.1 网络基础知识 一台主机需要配置必要的网络信息&#xff0c;才可以连接到互联网。需要的配置网络信息包括IP&#xff0c;子网掩码&#xff0c;网关和DNS。 11.1.1 IP地址 在计算机中对IP的标记使用的是32bit的二进制&#xff0c;例如&#xff0c; 11000000 10101000 00…

远程访问及控制

一、SSH远程管理 SSH(Secure Shell&#xff09;是一种安全通道协议&#xff0c;主要用来实现字符界面的远程登录&#xff0e;远程复制等功能。SSH 协议对通信双方的数据传输进行了加密处理&#xff0c;其中包括用户登录时输入的用户口令。与早期的Telent&#xff08;远程登录)、…

C++的多继承和虚继承

目录 多继承的定义和用法定义多继承多继承中派生类对象的内存布局访问基类成员多继承带来的问题 虚继承虚继承的语法虚继承对象的内存布局虚继承中的构造虚继承的缺点 多继承的定义和用法 C支持多继承&#xff0c;即一个派生类可以有多个基类。 很多时候&#xff0c;单继承就…

效果图渲染电脑渲染好?还是云渲染更好?

效果图的渲染是建筑和室内设计领域中不可或缺的一步&#xff0c;随着技术的发展&#xff0c;云渲染作为一项新技术&#xff0c;正逐渐受到人们关注。今天&#xff0c;让我们深入探讨电脑渲染和云渲染这两种方法的优缺点以及它们的适用场景。 本地电脑渲染 本地电脑渲染是利用用…

往年面试精选题目(前50道)

常用的集合和区别&#xff0c;list和set区别 Map&#xff1a;key-value键值对&#xff0c;常见的有&#xff1a;HashMap、Hashtable、ConcurrentHashMap以及TreeMap等。Map不能包含重复的key&#xff0c;但是可以包含相同的value。 Set&#xff1a;不包含重复元素的集合&#…

库函数atoi的功能及模拟实现

atoi函数的功能 int atoi(const char * str) 参数是字符指针&#xff0c;函数值是转换后的int型数据。使用时要包含头文件stdlib.h。 atoi函数的功能是&#xff1a;跳过不可见(空白)字符(如空格、换页\f、换行\n、回车\r、制表符\t、垂直制表符\v)&#xff0c;碰到正负号或…

在k8s中使用cert-manager部署gitlab集群

写在前面的话&#xff1a;前面有详细的分享过在k8s集群中部署gitlab&#xff0c;不过当时使用gitlab的访问证书是阿里云上免费的ssl证书&#xff0c;今天特意专门介绍下另外一种基于cert-manager发布自签证书的方式实现部署gitlab到k8s集群中。 往期gitlab部署系列如&#xff1…

麒麟信安桌面操作系统顺利上线长沙职业技术学院,深度促进产教融合,赋能信创人才培养

随着信息基础设施国产化进程的加快&#xff0c;信息技术创新产业对人才的需求量激增&#xff0c;为解决信创人才培养难题、深度促进产教融合&#xff0c;近日&#xff0c;麒麟信安、湖南欧拉生态创新中心携手长沙职业技术学院共同组建的“麒麟信安&欧拉(openEuler)国产操作…

【小黑嵌入式系统第十三课】PSoC 5LP第二个实验——中断控制实验

上一课&#xff1a; 【小黑嵌入式系统第十二课】μC/OS-III程序设计基础&#xff08;二&#xff09;——系统函数使用场合、时间管理、临界区管理、使用规则、互斥信号量 文章目录 1 实验目的2 实验要求3 实验设备4 实验原理4.1 中断(1) 中断机制概述(2) 中断源(3) 中断系统的功…

鸿蒙开发语言介绍--ArkTS

1.编程语言介绍 ArkTS是HarmonyOS主力应用开发语言。它在TypeScript (简称TS)的基础上&#xff0c;匹配ArkUI框架&#xff0c;扩展了声明式UI、状态管理等相应的能力&#xff0c;让开发者以更简洁、更自然的方式开发跨端应用。 2.TypeScript简介 自行补充TypeScript知识吧。h…

鸿蒙列表,item组件封装传参问题?@ObjectLink 和@Observerd

鸿蒙列表渲染&#xff0c;封装内容组件&#xff0c;进行item传参会报错&#xff1f; class FoodClass {order_id: number 0food_name: string ""food_price: number 0food_count: number 0 }Entry Component struct Demo07 {State message: string Hello World…