Hitachi Vantara Programming Contest 2024(AtCoder Beginner Contest 368)ABCDEF

2024-08-25 00:04

本文主要是介绍Hitachi Vantara Programming Contest 2024(AtCoder Beginner Contest 368)ABCDEF,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言

F比E简单多了,难评

A题:Cut

题意

给定n张卡片,将后m张卡片按顺序放置到顶部,按顺序输出卡片id

思路

更改输出方式即可

代码

inline void solve() {int n, m; cin >> n >> m;vector<int> a(n + 1);for (int i = 1; i <= n; i ++ ) cin >> a[i];for (int i = n - m + 1; i <= n; i ++ ) cout << a[i] << ' ';for (int i = 1; i <= n - m; i ++ ) cout << a[i] << ' ';return;
}

B题: Decrease 2 max elements

题意

对于一次操作,将整个数组降序sort一遍,并且将第一个和第二个元素的值减去一,问使得数组最多存在一个正整数的最小操作次数

思路

数据很小,并且是B题,不要多想,直接暴力

代码

inline void solve() {int n; cin >> n;vector<int> a(n + 1);for (int i = 1; i <= n; i ++ ) cin >> a[i];sort(a.begin() + 1, a.end(), greater<>());int cnt = 0;while (a[2] > 0) {a[1] -= 1, a[2] -= 1;sort(a.begin() + 1, a.end(), greater<>());cnt += 1;}cout << cnt << endl;return;
}

C题:Triple Attack 

题意

有n名敌人,我们每次攻击最前面那一个,定义T一开始为0,每进行一次攻击,会使得T值加一,当T是3的倍数的时候,攻击伤害为3,否则为1。问击败所有敌人所需的T

思路

这肯定跟周期有关了,在周期5的条件下,我们一共可以攻击5滴血。这个可以直接用除和模进行计算。

然后会剩下%5后的血量,我们直接进行模拟即可

代码

inline void solve() {int n; cin >> n;vector<int> a(n + 1);int cur = 1;ll ans = 0;for (int i = 1; i <= n; i ++ ) {int x; cin >> x;ans += x / 5 * 3;x %= 5;while (x) {int at = cur % 3 == 0 ? 3 : 1;int minv = min(at, x);x -= minv;cur += 1, ans += 1;}}cout << ans << endl;return;
}

D题:Minimum Steiner Tree 

题意

每次可以删去一个叶节点,问包含k个给定节点的最小树的大小是多少

思路

直接dfs,我们以一个给定的节点作为起点进行dfs,如果遇到了给定的节点,那么我们就要将这条路上的所有节点都进行“染色”(因为这些节点是到达此节点的必要条件)。最后输出染色的节点数量即可

代码

inline void solve() {int n, k; cin >> n >> k;vector<vector<int>> e(n + 1);for (int i = 1; i < n; i ++ ) {int a, b; cin >> a >> b;e[a].push_back(b), e[b].push_back(a);}map<int, int> vis;int st;for (int i = 1; i <= k; i ++ ) {int x; cin >> x;vis[x] = 1;st = x;}int ans = 0;vector<int> used(n + 1);function<void(int, int, vector<int>&)> dfs = [&](int u, int pre, vector<int>& path) {if (vis[u]) {for (int i = path.size() - 1; i >= 0; i -- ) {if (!used[path[i]]) used[path[i]] = 1, ans += 1;else break;}}for (int v : e[u]) {if (v == pre) continue;path.push_back(v);dfs(v, u, path);path.pop_back();}};vector<int> p;p.push_back(st);dfs(st, -1, p);cout << ans << endl;return;
}

E题:Train Delay 

题意

建议直接看原题进行理解

思路

模拟

首先我们将时间sort一遍,然后进行遍历

对于遍历到的点,要将其前面所有到达时间小于等于其出发时间的点对目的地的最低下限进行更新

什么意思呢?

10 20 1 2

30 40 2 3

四个信息分别为出发时间,到达时间,起点,终点

我们注意到30>20,那么对于终点2来说,其下限时间为20+它的推迟时间

此后遍历到的2的点的出发时间都要大于等于20+它的推迟时间

这个过程可以用优先队列进行模拟

代码

inline void solve() {int n, m, x; cin >> n >> m >> x;vector<ll> ans(m + 1);ans[1] = x;vector<array<int, 5>> p(m + 1);for (int i = 1; i <= m; i ++ ) {int a, b, s, t; cin >> a >> b >> s >> t;p[i] = {s, t, a, b, i};}sort(p.begin() + 1, p.end());using P = array<ll, 3>;priority_queue<P, vector<P>, greater<P>> q;vector<ll> d(n + 1);for (int i = 1; i <= m; i ++ ) {auto [s, t, a, b, id] = p[i];while (q.size() && q.top()[0] <= s) {auto [t1, t2, pos] = q.top();q.pop();d[pos] = max(d[pos], t2);}ans[id] = max(ans[id], d[a] - s);q.push({t, t + ans[id], b});}for (int i = 2; i <= m; i ++ ) cout << ans[i] << ' ';return;
}

F题:Dividing Game 

题意

见题目

思路

像,太像了。之前cf上也做过一道sg函数的,不过那个是猜的,这个可以明显计算

因为它进行的改变是将x变成小于其的任意正因数

所以我们预处理1e5的sg函数的时候,复杂度为1e5*sqrt(a)

这就直接处理出来了,秒了,比E简单100倍

你可能会注意到,下面用了一个while求sg函数

因为我打表前1000个,它的sg值就没有超过10,所以可以直接while遍历

代码

const int N = 1e5 + 9;
int sg[N];
inline void solve() {int n; cin >> n;int ans = 0;for (int i = 1; i <= n; i ++ ) {int x; cin >> x;ans ^= sg[x];}cout << (ans ? "Anna" : "Bruno") << endl;return;
}inline void pre_work() {sg[1] = 0;for (int i = 2; i <= 100000; i ++ ) {set<int> s;s.insert(0);for (int j = 2; j * j <= i; j ++ ) {if (i % j == 0) {s.insert(sg[j]);s.insert(sg[i / j]);}}int cur = 0;while (true) {if (!s.count(cur)) {sg[i] = cur;break;}cur += 1;}}
}

 

 

这篇关于Hitachi Vantara Programming Contest 2024(AtCoder Beginner Contest 368)ABCDEF的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1103986

相关文章

2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题

题库来源:安全生产模拟考试一点通公众号小程序 2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题是由安全生产模拟考试一点通提供,流动式起重机司机证模拟考试题库是根据流动式起重机司机最新版教材,流动式起重机司机大纲整理而成(含2024年流动式起重机司机证模拟考试题库及流动式起重机司机理论考试试题参考答案和部分工种参考解析),掌握本资料和学校方法,考试容易。流动式起重机司机考试技

【专题】2024飞行汽车技术全景报告合集PDF分享(附原数据表)

原文链接: https://tecdat.cn/?p=37628 6月16日,小鹏汇天旅航者X2在北京大兴国际机场临空经济区完成首飞,这也是小鹏汇天的产品在京津冀地区进行的首次飞行。小鹏汇天方面还表示,公司准备量产,并计划今年四季度开启预售小鹏汇天分体式飞行汽车,探索分体式飞行汽车城际通勤。阅读原文,获取专题报告合集全文,解锁文末271份飞行汽车相关行业研究报告。 据悉,业内人士对飞行汽车行业

高效录音转文字:2024年四大工具精选!

在快节奏的工作生活中,能够快速将录音转换成文字是一项非常实用的能力。特别是在需要记录会议纪要、讲座内容或者是采访素材的时候,一款优秀的在线录音转文字工具能派上大用场。以下推荐几个好用的录音转文字工具! 365在线转文字 直达链接:https://www.pdf365.cn/ 365在线转文字是一款提供在线录音转文字服务的工具,它以其高效、便捷的特点受到用户的青睐。用户无需下载安装任何软件,只

2024网安周今日开幕,亚信安全亮相30城

2024年国家网络安全宣传周今天在广州拉开帷幕。今年网安周继续以“网络安全为人民,网络安全靠人民”为主题。2024年国家网络安全宣传周涵盖了1场开幕式、1场高峰论坛、5个重要活动、15场分论坛/座谈会/闭门会、6个主题日活动和网络安全“六进”活动。亚信安全出席2024年国家网络安全宣传周开幕式和主论坛,并将通过线下宣讲、创意科普、成果展示等多种形式,让广大民众看得懂、记得住安全知识,同时还

2014 Multi-University Training Contest 8小记

1002 计算几何 最大的速度才可能拥有无限的面积。 最大的速度的点 求凸包, 凸包上的点( 注意不是端点 ) 才拥有无限的面积 注意 :  凸包上如果有重点则不满足。 另外最大的速度为0也不行的。 int cmp(double x){if(fabs(x) < 1e-8) return 0 ;if(x > 0) return 1 ;return -1 ;}struct poin

2014 Multi-University Training Contest 7小记

1003   数学 , 先暴力再解方程。 在b进制下是个2 , 3 位数的 大概是10000进制以上 。这部分解方程 2-10000 直接暴力 typedef long long LL ;LL n ;int ok(int b){LL m = n ;int c ;while(m){c = m % b ;if(c == 3 || c == 4 || c == 5 ||

2014 Multi-University Training Contest 6小记

1003  贪心 对于111...10....000 这样的序列,  a 为1的个数,b为0的个数,易得当 x= a / (a + b) 时 f最小。 讲串分成若干段  1..10..0   ,  1..10..0 ,  要满足x非递减 。  对于 xi > xi+1  这样的合并 即可。 const int maxn = 100008 ;struct Node{int

2024/9/8 c++ smart

1.通过自己编写的class来实现unique_ptr指针的功能 #include <iostream> using namespace std; template<class T> class unique_ptr { public:         //无参构造函数         unique_ptr();         //有参构造函数         unique_ptr(

论文翻译:arxiv-2024 Benchmark Data Contamination of Large Language Models: A Survey

Benchmark Data Contamination of Large Language Models: A Survey https://arxiv.org/abs/2406.04244 大规模语言模型的基准数据污染:一项综述 文章目录 大规模语言模型的基准数据污染:一项综述摘要1 引言 摘要 大规模语言模型(LLMs),如GPT-4、Claude-3和Gemini的快

免费也能高质量!2024年免费录屏软件深度对比评测

我公司因为客户覆盖面广的原因经常会开远程会议,有时候说的内容比较广需要引用多份的数据,我记录起来有一定难度,所以一般都用录屏工具来记录会议内容。这次我们来一起探索有什么免费录屏工具可以提高我们的工作效率吧。 1.福晰录屏大师 链接直达:https://www.foxitsoftware.cn/REC/  录屏软件录屏功能就是本职,这款录屏工具在录屏模式上提供了多种选项,可以选择屏幕录制、窗口