Codeforces Round 929 (Div. 3)

在这里插入图片描述

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.hqwc.cn/news/498537.html

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

相关文章

win11开启IPV6并手动设置地址

win11开启IPV6并手动设置地址 ipv6手动设置 假设你想要配置的IPv6地址是2001:0db8:85a3:0000:0000:8a2e:0370:7334&#xff0c;子网前缀长度为64位&#xff0c;并且默认网关是2001:0db8:85a3::1。 手动配置IPv6地址的示例步骤&#xff08;Windows操作系统&#xff09;&#x…

[云原生] k8s之pod容器

一、pod的相关知识 1.1 Pod基础概念 Pod是kubernetes中最小的资源管理组件&#xff0c;Pod也是最小化运行容器化应用的资源对象。一个Pod代表着集群中运行的一个进程。kubernetes中其他大多数组件都是围绕着Pod来进行支撑和扩展Pod功能的&#xff0c;例如&#xff0c;用于管理…

基于springboot+vue的保险信息网站(源码+论文)

文章目录 文章目录 前言 一、功能设计 二、功能实现 2.1 前台功能设计 2.1.1 网站首页 2.1.2 保险产品列表 2.1.3 留言板界面 2.1.4 产品查询界面 2.2后台管理设计 2.2.1 系统用户登录管理 三、库表设计 四、论文 前言 随着互联网的不断发展&#xff0c;现在人们获…

IP源防攻击IPSG(IP Source Guard)

IP源防攻击IPSG&#xff08;IP Source Guard&#xff09;是一种基于二层接口的源IP地址过滤技术&#xff0c;它能够防止恶意主机伪造合法主机的IP地址来仿冒合法主机&#xff0c;还能确保非授权主机不能通过自己指定IP地址的方式来访问网络或攻击网络。 2.1 IPSG基本原理 绑定…

网络:IPv6

1、由于IPv4地址资源枯竭&#xff0c;所以产生了IPV6。 版本长度地址数量IPv432 bit4 294 967 296IPv6128 bit340 282 366 920 938 463 374 607 431 768 211 456 2、IPv6的基本报头在IPv4报头基础上&#xff0c;增加了流标签域&#xff0c;去除了一些冗余字段&#xff0c;使报…

提升工作满意度:让AI绩效评估指南助你一臂之力

绩效管理革命&#xff1a;如何通过AI提升企业效率 在我们所辅导及接触的众多企业中&#xff0c;愈发显著的是&#xff0c;越来越多企业提出了对于绩效管理体系建立的需求。这一需求的提出是因为许多企业并未设定明确目标&#xff0c;导致员工缺乏明确的工作导向。 在现状下&…

55.仿简道云公式函数实战-文本函数-MID

1. MID函数 返回文本字符串中从指定位置开始的特定数目的字符&#xff0c;该数目由用户指定。 2. 函数用法 MID(text, start_num, num_chars) 3. 函数示例 返回文本字符串中从指定位置开始的特定数目的字符&#xff0c;该数目由用户指定。 text: 必需。 包含要提取字符的文…

Python多线程编程:深入理解threading模块及代码实战【第99篇—Multiprocessing模块】

Python多线程编程&#xff1a;深入理解threading模块及代码实战 在Python编程中&#xff0c;多线程是一种常用的并发编程方式&#xff0c;它可以有效地提高程序的执行效率&#xff0c;特别是在处理I/O密集型任务时。Python提供了threading模块&#xff0c;使得多线程编程变得相…

基于最小二乘正弦拟合算法的信号校正matlab仿真,校正幅度,频率以及时钟误差,输出SNDR,SFDR,ENOB指标

目录 1.算法运行效果图预览 2.算法运行软件版本 3.部分核心程序 4.算法理论概述 4.1 最小二乘正弦拟合 4.2 SNDR、SFDR 和 ENOB 计算 4.3 校正 5.算法完整程序工程 1.算法运行效果图预览 2.算法运行软件版本 matlab2022a 3.部分核心程序 ..........................…

个人博客系列-Django部署-nginx(3)

使用Nginx uwsgi进行部署django项目 一. 检查项目是否可以运行 启动项目 python manage.py runserver 0.0.0.0:8099输入ip:8099 查看启动页面 出现上述页面表示运行成功 二. 安装uwsgi并配置 2.1 下载uwsgi pip install uwsgi新建文件test.py写入内容&#xff0c;测试一…

【GB28181】wvp-GB28181-pro修改分屏监控为16画面(前端)

引言 作为一个非前端开发人员,自己摸索起来比较费劲,也浪费了很多时间 由于实际开发中,可能预览的画面多于8个,而wvp目前只支持8画面 本文快速帮助开发者修改分屏监控为多画面。例如16画面,20画面等 文章目录 一、 预期效果展示16分割画面20分割画面二、 源码修改-前端修改…

【Linux C | 网络编程】gethostbyname 函数详解及C语言例子

&#x1f601;博客主页&#x1f601;&#xff1a;&#x1f680;https://blog.csdn.net/wkd_007&#x1f680; &#x1f911;博客内容&#x1f911;&#xff1a;&#x1f36d;嵌入式开发、Linux、C语言、C、数据结构、音视频&#x1f36d; &#x1f923;本文内容&#x1f923;&a…