当前位置: 首页 > news >正文

AtCoder Beginner Contest 368

A.Cut(模拟)

题意:

有一叠 N N N张扑克牌,最上面的 i i i张扑克牌上写着一个整数 A _ i A\_i A_i

你从牌堆底部取出 K K K张牌,将它们放在牌堆顶部,并保持它们的顺序。

操作后从上到下输出写在卡片上的整数。

分析:

我们先从 n − k + 1 n-k+1 nk+1输出到 n n n,再从 1 1 1输出到 n − k n-k nk

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
#define endl '\n'
#define PII pair<LL, LL>
const int maxn = 2e5 + 10;
const int INF = 2e9 + 5;
const int mod = 998244353;
int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n, k;cin >> n >> k;vector<int> a(n + 1);for (int i = 1; i <= n; i++)cin >> a[i];for (int i = n - k + 1; i <= n; i++)cout << a[i] << " ";for (int i = 1; i <= n - k; i++)cout << a[i] << " ";cout << endl;return 0;
}

B.Decrease 2 max elements(模拟)

题意:

给你一个由 N N N个正整数 A = ( A _ 1 , A _ 2 , … , A _ N ) A = (A\_1, A\_2, \dots ,A\_N) A=(A_1,A_2,,A_N)组成的序列。高桥重复下面的操作,直到 A A A包含的正整数元素不超过一个:

  • 按降序排列 A A A。然后将 A _ 1 A\_1 A_1 A _ 2 A\_2 A_2减少 1 1 1

询问他执行此操作的次数。

分析:

我们用优先队列进行模拟,每次取出两个最小的,分别减 1 1 1,再加回到队列。直到第二小的不为正数。

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
#define endl '\n'
#define PII pair<LL, LL>
const int maxn = 2e5 + 10;
const int INF = 2e9 + 5;
const int mod = 998244353;
int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n;cin >> n;priority_queue<int> tmp;for (int i = 1; i <= n; i++){int x;cin >> x;tmp.push(x);}int ans = 0;while (1){int a = tmp.top();tmp.pop();int b = tmp.top();tmp.pop();if (b <= 0)break;a--;b--;ans++;tmp.push(a), tmp.push(b);}cout << ans << endl;return 0;
}

C.Triple Attack(思维)

题意:

你正在玩一个游戏。

N N N个敌人排成一排,最前面的 i i i个敌人的健康值是 H _ i H\_i H_i

你将使用初始化为 0 0 0的变量 T T T重复以下操作,直到所有敌人的生命值都变为 0 0 0或更少。

  • T T T增加 1 1 1。然后,攻击最前方生命值大于等于 1 1 1的敌人。如果 T T T 3 3 3的倍数,敌人的生命值会减少 3 3 3;否则,生命值会减少 1 1 1

当所有敌人的生命值变为 0 0 0或更少时,求 T T T的值。

分析:

我们发现每三次攻击敌人都会扣 5 5 5滴血,对于敌人剩下小于 5 5 5滴血的情况,我们特判攻击次数是否是三的倍数即可。

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
#define endl '\n'
#define PII pair<LL, LL>
const int maxn = 2e5 + 10;
const int INF = 2e9 + 5;
const int mod = 998244353;
int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n;cin >> n;LL ans = 0;for (int i = 0; i < n; i++){int h;cin >> h;ans += (h / 5) * 3;h %= 5;while (h > 0){ans++;if (ans % 3 == 0){h -= 3;}else{h--;}}}cout << ans << endl;return 0;
}

D.Minimum Steiner Tree(DFS)

题意:

给你一棵树,树上有 N N N个顶点,编号为 1 1 1 N N N。第 i i i条边连接顶点 A _ i A\_i A_i B _ i B\_i B_i

考虑从这个图中删除一些边和顶点(可能为零)后可以得到一棵树。求这样一棵树中包含所有 K K K指定顶点 V _ 1 , … , V _ K V\_1,\ldots,V\_K V_1,,V_K的顶点的最小数目。

分析:

我们以第一个保留的点为根,进行 d f s dfs dfs。在 d f s dfs dfs过程中的当前点 u u u,判断其是否需要保留,那么我们就需要知道其子树是否有需要保留的点,有则当前点 u u u需要保留。因此 D F S DFS DFS返回的东西即为该子树是否有需要保留的点。

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
#define endl '\n'
#define PII pair<LL, LL>
const int maxn = 2e5 + 10;
const int INF = 2e9 + 5;
const int mod = 998244353;
vector<int> e[maxn];
int tmp[maxn], ans;
void dfs(int u, int fa)
{for (auto v : e[u]){if (v == fa)continue;dfs(v, u);if (tmp[v])tmp[u] = 1;}
}
int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n, k;cin >> n >> k;for (int i = 1; i < n; i++){int u, v;cin >> u >> v;e[u].push_back(v), e[v].push_back(u);}int x;for (int i = 1; i <= k; i++){cin >> x;tmp[x] = 1;}dfs(x, -1);for (int i = 1; i <= n; i++)ans += tmp[i];cout << ans << endl;return 0;
}

E.Train Delay (思维)

题意:

在 Atcoder 国家,有 N N N座城市,编号为 1 1 1 N N N,以及 M M M列火车,编号为 1 1 1 M M M。列车 i i i S _ i S\_i S_i时刻从城市 A _ i A\_i A_i出发,在 T _ i T\_i T_i时刻到达城市 B _ i B\_i B_i

给定一个正整数 X _ 1 X\_1 X_1,请你找到一组满足下列条件的非负整数 X _ 2 , … , X _ M X\_2,\ldots,X\_M X_2,,X_M,使得他们的和 X _ 2 + … + X _ M X\_2+\ldots+X\_M X_2++X_M最小。

  • 条件对于所有满足 1 ≤ i , j ≤ M 1 \leq i,j \leq M 1i,jM的一对 ( i , j ) (i,j) (i,j),如果 B _ i = A _ j B\_i=A\_j B_i=A_j T _ i ≤ S _ j T\_i \leq S\_j T_iS_j,那么 T _ i + X _ i ≤ S _ j + X _ j T\_i+X\_i \leq S\_j+X\_j T_i+X_iS_j+X_j

    • 换句话说,对于任何一对原本可以换乘的列车,即使将每列列车 i i i的出发和到达时间延迟 X _ i X\_i X_i,仍然可以换乘。

可以证明,满足这样条件的 ,且和 X _ 2 + … + X _ M X\_2+\ldots+X\_M X_2++X_M最小的序列 X _ 2 , … , X _ M X\_2,\ldots,X\_M X_2,,X_M是唯一的。

分析:

我们需要知道所有列车的最早发车时间。那么 X [ i ] = X[i]= X[i]=开车时间 - 原始开车时间。所以我们将所有时间从小到大排序,遍历到的每一个出发时间,能赶上他的所有到达时间已经遍历过。那么这辆车的最早开车时间就是:所有能赶上他的车中,到达时间的最大值。这样就能得知所有的 X [ i ] X[i] X[i]。 最后就只需要记录每个车站目前的最晚到达时间即可。

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
#define endl '\n'
#define PII pair<LL, LL>
const int N = 2e5 + 10;
const int INF = 2e9 + 5;
const int mod = 998244353;
int n, m, x;
LL a[N], b[N], s[N], t[N], delay[N], arrival[N];
struct event
{LL type, time, id;
} tmp[N << 1];int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n, m, x;cin >> n >> m >> x;for (int i = 1; i <= m; i++){cin >> a[i] >> b[i] >> s[i] >> t[i];tmp[2 * i - 1] = {0, s[i], i};tmp[2 * i] = {1, t[i], i};}sort(tmp + 1, tmp + 2 * m + 1, [&](event a, event b){if (a.time == b.time) {return a.type > b.type;}return a.time < b.time; });delay[1] = x;for (int i = 1, stat; i <= 2 * m; i++){if (tmp[i].type == 0){stat = a[tmp[i].id];if (tmp[i].id != 1)delay[tmp[i].id] = max(0ll, arrival[stat] - tmp[i].time);}else{stat = b[tmp[i].id];arrival[stat] = max(arrival[stat], tmp[i].time + delay[tmp[i].id]);}}for (int i = 2; i <= m; i++)cout << delay[i] << " ";cout << endl;return 0;
}

F.Rearrange Query (博弈论)

题意:

给你一个由 N N N个正整数 A = ( A _ 1 , A _ 2 , … , A _ N ) A = (A\_1, A\_2, \dots ,A\_N) A=(A_1,A_2,,A_N)组成的序列,其中每个元素至少是 2 2 2。安娜和布鲁诺用这些整数玩一个游戏。他们轮流执行以下操作,安娜先执行。

  • 自由选择一个整数 i ( 1 ≤ i ≤ N ) i \ (1 \leq i \leq N) i (1iN)。然后,自由选择一个不是 A _ i A\_i A_i本身的 、 A _ i A\_i A_i的因数 x x x,并用 x x x代替 A _ i A\_i A_i

不能进行操作的一方输,另一方赢。假设两位棋手都以最佳的方式行动,那么谁会获胜?

分析:

每个 A [ i ] A[i] A[i]可以操作的次数是 A [ i ] A[i] A[i]的质因子个数,设为 B [ i ] B[i] B[i],那么所有的 B [ i ] B[i] B[i]异或值不为 0 0 0时,则先手必胜;否则,则先手必败。如果异或和为 0 0 0,那么先手无论如何取数,后手都可以通过操作,使得异或和保持为 0 0 0,直到数列 A A A全为 0 0 0,先手不能取数,必败。

代码:

#include <bits/stdc++.h>
using namespace std;
typedef long long LL;
#define endl '\n'
#define PII pair<LL, LL>
const int N = 2e5 + 10;
const int INF = 2e9 + 5;
const int mod = 998244353;
int len[N];
int main()
{ios::sync_with_stdio(0);cin.tie(0);cout.tie(0);int n;cin >> n;for (int i = 1; i <= 1e5; i++){for (int j = i * 2; j <= 1e5; j += i)len[j] = max(len[j], len[i] + 1);}int flag = 0;for (int i = 0; i < n; i++){int x;cin >> x;flag ^= len[x];}if (flag == 0)cout << "Bruno" << endl;elsecout << "Anna" << endl;return 0;
}
s

赛后交流

在比赛结束后,会在交流群中给出比赛题解,同学们可以在赛后查看题解进行补题。

群号: 704572101,赛后大家可以一起交流做题思路,分享做题技巧,欢迎大家的加入。

相关文章:

AtCoder Beginner Contest 368

A.Cut&#xff08;模拟&#xff09; 题意&#xff1a; 有一叠 N N N张扑克牌&#xff0c;最上面的 i i i张扑克牌上写着一个整数 A _ i A\_i A_i。 你从牌堆底部取出 K K K张牌&#xff0c;将它们放在牌堆顶部&#xff0c;并保持它们的顺序。 操作后从上到下输出写在卡…...

WebGL系列教程六(纹理映射与立方体贴图)

目录 1 前言2 思考题3 纹理映射介绍4 怎么映射&#xff1f;5 开始绘制5.1 声明顶点着色器和片元着色器5.2 修改顶点的颜色为纹理坐标5.3 指定顶点位置和纹理坐标的值5.4 获取图片成功后进行绘制5.5 效果5.6 完整代码 6 总结 1 前言 上一讲我们讲了如何使用索引绘制彩色立方体&a…...

为什么nii.gz转.nrrd标签体积变大?

import SimpleITK as sitk # nii nii.gz nrrd格式之间互相转换 def nii2nii(oripath, savepath):data sitk.ReadImage(oripath)img sitk.GetArrayFromImage(data)out sitk.GetImageFromArray(img)sitk.WriteImage(out, savepath)if __name__ __main__:oripath 00292625.ni…...

软件安装攻略:EmEditor编辑器下载安装与使用

EmEditor是一款在Windows平台上运行的文字编辑程序。EmEditor以运作轻巧、敏捷而又功能强大、丰富著称&#xff0c;得到许多用户的好评。Windows内建的记事本程式由于功能太过单薄&#xff0c;所以有不少用户直接以EmEditor取代&#xff0c;emeditor是一个跨平台的文本编辑器&a…...

Redis的watch机制详解

WATCH 是 Redis 提供的一个用于实现 乐观锁 (Optimistic Lock) 的命令&#xff0c;通常用于实现事务中的并发控制。它允许客户端监控一个或多个键的变化&#xff0c;并确保事务&#xff08;MULTI/EXEC&#xff09;中执行的操作在这些键没有发生改变的情况下才能成功提交。若在事…...

UnrealEngine 打包Android平台应用

虚幻引擎 支持将项目发布到 安卓&#xff08;Android&#xff09; 移动设备上&#xff0c;并且提供了若干功能帮你将项目发布到 谷歌游戏商店。本节包含了如何设置Android开发环境、如何使用Android功能和服务、以及如何为发布游戏做准备相关的指南。 当前SDK要求 当前UE版本…...

Linux:git

hello&#xff0c;各位小伙伴&#xff0c;本篇文章跟大家一起学习《Linux&#xff1a;git》&#xff0c;感谢大家对我上一篇的支持&#xff0c;如有什么问题&#xff0c;还请多多指教 &#xff01; 如果本篇文章对你有帮助&#xff0c;还请各位点点赞&#xff01;&#xff01;&…...

electron有关mac构建

针对 Mac M1/2/3 芯片的设备&#xff0c;proces.archarm64. 执行下面命令&#xff0c;检查下按照的 node.js 版本是不是 intel x64 指令集&#xff0c;如果是的话安装下 arm64 指令集的 node.js终端中执行以下命令&#xff1a;node -p process.arch 对应的node版本也是arm版 …...

C语言-数据结构 弗洛伊德算法(Floyd)邻接矩阵存储

弗洛伊德算法相比迪杰斯特拉相似的地方都是遍历邻接矩阵不断调整最短路径的信息&#xff0c;并且两种算法面对多源最短路径的时间复杂度都是O(n^3)&#xff0c;Floyd采用的是动态规划而Dijkstra是采用贪心的思想。在Floyd中我们将创建两个数组进行辅助&#xff0c;一个path二维…...

pyspark 安装记录

1、安装软件 1、python 3.10 2、hadoop-3.3.4 里面的winutils 要记得添加 3、java-17 4、spark-3.5.1-bin-hadoop3 python 安装 pyspark,Jupyter notebook pip install pyspark pip install jupyter notebook 2、添加环境变量 JAVA_HOME=C:\PySparkService\java-17H…...

高度可定制的电竞鼠标,雷柏VT1 PRO MAX体验

不管是菜鸟还是老鸟&#xff0c;游戏玩到某个阶段很容易出现瓶颈&#xff0c;在游戏的某个阶段&#xff0c;这里面制约最大的除了操作之外&#xff0c;实际上还是我们用的硬件。比如在PC游戏中&#xff0c;鼠标的影响就非常大&#xff0c;像是在游戏中如果鼠标延迟过高&#xf…...

经验笔记:SOA(面向服务的架构)

SOA&#xff08;面向服务的架构&#xff09;经验笔记 引言 SOA&#xff08;Service-Oriented Architecture, 面向服务的架构&#xff09;是一种设计原则&#xff0c;用于构建灵活且可扩展的分布式系统。SOA强调将应用程序的不同功能封装为独立的服务&#xff0c;这些服务通过…...

triton之ttir学习

一 基本语句 1 常量 %cst arith.constant dense<520192> : tensor<4096xi32> %c127_i32 arith.constant 127 : i32 %cst arith.constant dense<520192> : tensor<4096xi32> 解释&#xff1a;这条语句定义了一个名为 %cst 的常量&#xff0c;它…...

如何在AWS账户上进行充值:一份详尽指南

大家好&#xff0c;小编今天给大家带来一份关于如何在AWS账户上进行充值的详尽指南。对于使用AWS服务的用户来说&#xff0c;保持账户余额充足是确保服务不中断的关键。下面&#xff0c;九河云将详细讲解具体的操作步骤。 步骤一&#xff1a;登录AWS管理控制台 首先&#xff…...

(六十四)第 10 章 内部排序(静态链表的插入排序)

示例代码 staticLinkList.h // 静态链表的插入排序实现头文件#ifndef STATIC_LINK_LIST_H #define STATIC_LINK_LIST_H#include "errorRecord.h"#define SIZE 100 #define NUM 8typedef int InfoType; typedef int KeyType;typedef struct {KeyType key;InfoType inf…...

appium历史版本地址链接

appium / Appium.app / Downloads — Bitbucket ios的appium界面图 链接: https://pan.baidu.com/s/1i8BRaZgQA3ImLUhKZjfhiA 提取码: 5c8b...

TCPIP网络编程(尹圣雨)UDP 轮流收发消息(windows)

端口号写的是 2345 客户端 #include <iostream> #include <winsock2.h> #pragma comment(lib, "ws2_32.lib")using std::cout; using std::endl; using std::cin;int main() {WSADATA wsa;if (WSAStartup(MAKEWORD(2, 2), &wsa) ! 0){cout <<…...

【相机方案(2)】V4L2 支持相机图像直接进入GPU内存吗?DeepStream 确实可以将图像数据高效地放入GPU内存进行处理!

V4L2 支持相机图像直接进入GPU内存吗&#xff1f; V4L2&#xff08;Video4Linux Two&#xff09;是Linux内核中用于视频捕获和播放的API&#xff0c;它本身并不直接支持将相机捕获的图像数据直接拷贝到GPU内存而不经过CPU内存。V4L2主要关注于视频设备的控制、数据的捕获和播放…...

UEFI——PEI阶段

一、PEI介绍 Pre-EFI Initialization&#xff08;PEI&#xff09;在引导的早期被调用&#xff0c;仅利用CPU资源调用PEIM&#xff0c;这些PEIM负责&#xff1a; &#xff08;1&#xff09;初始化一些永久内存 &#xff08;2&#xff09;在HOBs中描述内存信息 &#xff08;3…...

Nacos下载和启动

Nacos是什么&#xff1f; 一个更易于构建云原生应用的动态服务发现、配置管理和服务管理平台 下载 https://github.com/alibaba/nacos/releases/tag/2.1.1启动 将下载好的Nacos解压缩&#xff0c;然后到bin目录下打开cmd 输入指令&#xff1a;startup.cmd -m standalone 出…...

eNSP-Cloud(实现本地电脑与eNSP内设备之间通信)

说明&#xff1a; 想象一下&#xff0c;你正在用eNSP搭建一个虚拟的网络世界&#xff0c;里面有虚拟的路由器、交换机、电脑&#xff08;PC&#xff09;等等。这些设备都在你的电脑里面“运行”&#xff0c;它们之间可以互相通信&#xff0c;就像一个封闭的小王国。 但是&#…...

【Redis技术进阶之路】「原理分析系列开篇」分析客户端和服务端网络诵信交互实现(服务端执行命令请求的过程 - 初始化服务器)

服务端执行命令请求的过程 【专栏简介】【技术大纲】【专栏目标】【目标人群】1. Redis爱好者与社区成员2. 后端开发和系统架构师3. 计算机专业的本科生及研究生 初始化服务器1. 初始化服务器状态结构初始化RedisServer变量 2. 加载相关系统配置和用户配置参数定制化配置参数案…...

Golang dig框架与GraphQL的完美结合

将 Go 的 Dig 依赖注入框架与 GraphQL 结合使用&#xff0c;可以显著提升应用程序的可维护性、可测试性以及灵活性。 Dig 是一个强大的依赖注入容器&#xff0c;能够帮助开发者更好地管理复杂的依赖关系&#xff0c;而 GraphQL 则是一种用于 API 的查询语言&#xff0c;能够提…...

Spring AI 入门:Java 开发者的生成式 AI 实践之路

一、Spring AI 简介 在人工智能技术快速迭代的今天&#xff0c;Spring AI 作为 Spring 生态系统的新生力量&#xff0c;正在成为 Java 开发者拥抱生成式 AI 的最佳选择。该框架通过模块化设计实现了与主流 AI 服务&#xff08;如 OpenAI、Anthropic&#xff09;的无缝对接&…...

代理篇12|深入理解 Vite中的Proxy接口代理配置

在前端开发中,常常会遇到 跨域请求接口 的情况。为了解决这个问题,Vite 和 Webpack 都提供了 proxy 代理功能,用于将本地开发请求转发到后端服务器。 什么是代理(proxy)? 代理是在开发过程中,前端项目通过开发服务器,将指定的请求“转发”到真实的后端服务器,从而绕…...

莫兰迪高级灰总结计划简约商务通用PPT模版

莫兰迪高级灰总结计划简约商务通用PPT模版&#xff0c;莫兰迪调色板清新简约工作汇报PPT模版&#xff0c;莫兰迪时尚风极简设计PPT模版&#xff0c;大学生毕业论文答辩PPT模版&#xff0c;莫兰迪配色总结计划简约商务通用PPT模版&#xff0c;莫兰迪商务汇报PPT模版&#xff0c;…...

【p2p、分布式,区块链笔记 MESH】Bluetooth蓝牙通信 BLE Mesh协议的拓扑结构 定向转发机制

目录 节点的功能承载层&#xff08;GATT/Adv&#xff09;局限性&#xff1a; 拓扑关系定向转发机制定向转发意义 CG 节点的功能 节点的功能由节点支持的特性和功能决定。所有节点都能够发送和接收网格消息。节点还可以选择支持一个或多个附加功能&#xff0c;如 Configuration …...

小木的算法日记-多叉树的递归/层序遍历

&#x1f332; 从二叉树到森林&#xff1a;一文彻底搞懂多叉树遍历的艺术 &#x1f680; 引言 你好&#xff0c;未来的算法大神&#xff01; 在数据结构的世界里&#xff0c;“树”无疑是最核心、最迷人的概念之一。我们中的大多数人都是从 二叉树 开始入门的&#xff0c;它…...

C++_哈希表

本篇文章是对C学习的哈希表部分的学习分享 相信一定会对你有所帮助~ 那咱们废话不多说&#xff0c;直接开始吧&#xff01; 一、基础概念 1. 哈希核心思想&#xff1a; 哈希函数的作用&#xff1a;通过此函数建立一个Key与存储位置之间的映射关系。理想目标&#xff1a;实现…...

用神经网络读懂你的“心情”:揭秘情绪识别系统背后的AI魔法

用神经网络读懂你的“心情”:揭秘情绪识别系统背后的AI魔法 大家好,我是Echo_Wish。最近刷短视频、看直播,有没有发现,越来越多的应用都开始“懂你”了——它们能感知你的情绪,推荐更合适的内容,甚至帮客服识别用户情绪,提升服务体验。这背后,神经网络在悄悄发力,撑起…...