2024.3.11 训练记录(14)

继续补题

文章目录

  • ICPC 2018青岛I Soldier Game
  • ICPC 2018青岛K Airdrop

ICPC 2018青岛I Soldier Game

题目链接

线段树

果然稍微复杂一点的线段树就很难实现啊,不看题解根本没反应过来是线段树

struct Node
{int l, r, lb, rb, nb, b;
} tr[N * 4];

其中:

  • lb 表示 a[l] 不包含在区间之内,即 a[l] 包含在 [l - 1, l]
  • rb 表示 a[r] 不包含在区间之内,即 a[r] 包含在 [r, r + 1]
  • nb 表示 a[l]a[r] 都不包含在区间之内,即 a[l] 包含在 [l - 1, l] 中,a[r] 包含在 [r, r + 1]
  • b 表示 a[l]a[r] 都包含在区间之内,即 a[l] 包含在 [l, l][l, l + 1] 内, a[r] 包含在 [r, r][r - 1, r]

合并操作可以看这张图:
在这里插入图片描述

#include <bits/stdc++.h>using namespace std;#define int long long
using i64 = long long;typedef pair<int, int> PII;
typedef pair<double, double> PDD;
typedef pair<int, PII> PIII;const int N = 1e5 + 10;
const int mod = 1e9 + 7;
const int maxn = 1e6 + 10;
const int mod1 = 954169327;
const int mod2 = 906097321;
const int INF = 0x3f3f3f3f3f3f3f3f;int n;
int a[N];
struct Node
{int l, r, lb, rb, nb, b; // 分别表示左边界不包含 右边界不包含 两边界都不包含 两边界都包含
} tr[N * 4];void pushup(Node& u, Node& l, Node& r)
{u.l = l.l, u.r = r.r;u.lb = min(max(l.lb, r.b), max(l.nb, r.lb));u.rb = min(max(l.b, r.rb), max(l.rb, r.nb));u.nb = min(max(l.lb, r.rb), max(l.nb, r.nb));u.b = min(max(l.b, r.b), max(l.rb, r.lb));
}void pushup(int u)
{pushup(tr[u], tr[u << 1], tr[u << 1 | 1]);
}void build(int u, int l, int r)
{tr[u] = {l, r};if (l == r){tr[u].lb = (l > 1 ? -INF : INF);tr[u].rb = (l == n ? INF : a[l] + a[l + 1]);tr[u].nb = INF;tr[u].b = a[l];return;}int mid = l + r >> 1;build(u << 1, l, mid), build(u << 1 | 1, mid + 1, r);pushup(u);return;
}void modify(int u, int pos, int len)
{if (tr[u].l == pos && tr[u].r == pos){if (len == 1) tr[u].b = INF;else tr[u].rb = INF;return;}int mid = tr[u].l + tr[u].r >> 1;if (pos <= mid) modify(u << 1, pos, len);else modify(u << 1 | 1, pos, len);pushup(u);
}Node query(int u, int l, int r)
{if (tr[u].l >= l && tr[u].r <= r) return tr[u];int mid = tr[u].l + tr[u].r >> 1;if (r <= mid) return query(u << 1, l, r);else if (l > mid) return query(u << 1 | 1, l, r);else{Node res;auto left = query(u << 1, l, mid);auto right = query(u << 1 | 1, mid + 1, r);pushup(res, left, right);return res;}
}void solve()
{cin >> n;for (int i = 1; i <= n; i ++ ) cin >> a[i];build(1, 1, n);vector<PIII> vec;for (int i = 1; i <= n; i ++ ){vec.push_back({a[i], {i, 1}});if (i != n) vec.push_back({a[i] + a[i + 1], {i, 2}});}sort(vec.begin(), vec.end());int ans = INF;for (int i = 0; i < 2 * n - 1; i ++ ){ans = min(ans, query(1, 1, n).b - vec[i].first);modify(1, vec[i].second.first, vec[i].second.second);}cout << ans << '\n';
}signed main()
{ios::sync_with_stdio(false);cin.tie(0), cout.tie(0);int t = 1;cin >> t;while (t -- ){solve();}
}

ICPC 2018青岛K Airdrop

题目链接

要说算法好像也没什么算法,原来金牌题也有纯思维吗,但是补得好困难啊

首先改变一下坐标轴,把 y = y0 作为 x 轴,因为所有人都是先上下再左右的,所以一定是先挪到 y 0 y_0 y0 这条线上再靠近 x 0 x_0 x0,同时处在 y 0 y_0 y0 两边的人是不可能相遇的,所以可以遍历 x 0 x_0 x0,判断处在左右两边的人对答案各贡献多少

下方以统计左侧为例说明统计方法

当然也是不能暴力统计的,我们注意到 x 0 x_0 x0 往右移的时候,左侧的人的曼哈顿距离都增加1,所以左侧原先贡献是多少,现在贡献还是多少

然后要看,上一次在 x = x 0 x=x_0 x=x0 上距离相等的点最多有 2 个,并且在 − d -d d d d d 的位置,这一次 x 轴右移,导致如果这两个点都存在,他俩就会撞死,同时还可能存在本来就在左侧的点和新出现在左侧的点曼哈顿距离一样,那他们就会一起撞死,只有这些情况的人数是1的时候才会对答案有1的贡献

我们只需要关注每个 x 和距离 x 为 1 的点

这题的另一个收获就是,开范围为 N 的数据结构时一定要开在最外面,开在里面会T

#include <bits/stdc++.h>using namespace std;#define int long long
using i64 = long long;typedef pair<int, int> PII;
typedef pair<double, double> PDD;
typedef pair<int, PII> PIII;const int N = 1e5 + 10;
const int mod = 1e9 + 7;
const int maxn = 1e6 + 10;
const int mod1 = 954169327;
const int mod2 = 906097321;
const int INF = 0x3f3f3f3f3f3f3f3f;unordered_map<int, int> mp[N];
vector<int> L(N), R(N);void solve()
{int n, y0;cin >> n >> y0;vector<int> x(n + 1), y(n + 1);for (int i = 1; i <= n; i ++ ){cin >> x[i] >> y[i];y[i] -= y0;}vector<int> pos;for (int i = 1; i <= n; i ++ ){mp[x[i]][abs(y[i])] ++ ;for (int j = -1; j <= 1; j ++ ) pos.push_back(x[i] + j);}auto cal = [&](vector<int>& pos, vector<int>& f){unordered_set<int> st;int dist = 0;f[pos[0]] = 0;for (int i = 1; i < pos.size(); i ++ ){int x_now = pos[i], lst = pos[i - 1];if (mp[lst].size() > 0){for (auto t : mp[lst]){int yp = t.first, cnt = t.second;if (st.count(yp - dist) + cnt == 1) st.insert(yp - dist);else st.erase(yp - dist);}}dist += abs(x_now - lst);f[x_now] = st.size();}return;};sort(pos.begin(), pos.end());pos.erase(unique(pos.begin(), pos.end()), pos.end());cal(pos, L);reverse(pos.begin(), pos.end());cal(pos, R);int ans_max = 0, ans_min = INF;for (int i = 0; i < pos.size(); i ++ ){int xp = pos[i];int tmp = L[xp] + R[xp];if (mp[xp].size() > 0) for (auto t : mp[xp]) tmp += t.second;ans_max = max(ans_max, tmp);ans_min = min(ans_min, tmp);}cout << ans_min << ' ' << ans_max << '\n';for (int i = 0; i < pos.size(); i ++ ) mp[pos[i]].clear(), L[pos[i]] = R[pos[i]] = 0;
}signed main()
{ios::sync_with_stdio(false);cin.tie(0), cout.tie(0);int t = 1;cin >> t;while (t -- ){solve();}
}

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

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

相关文章

事物的传播属性

事务传播属性是Spring框架在处理事务时的一个重要概念&#xff0c;它定义了在事务方法被另一个事务方法调用时&#xff0c;如何处理事务边界的行为。这些属性是通过Spring的Transactional注解中的propagation属性来设置的。下面是几个常见的Spring事务传播属性&#xff1a; *RE…

迄今为止易用 —— 的 “盲水印“ 实现方案

前期回顾 网站的打赏 —— 新一代的思路-CSDN博客https://blog.csdn.net/m0_57904695/article/details/136704914?spm1001.2014.3001.5501 目录 CSDN 彩色之外 &#x1f4dd; 前言&#xff1a; &#x1f6e0;️ vue3-blind-watermark &#x1f916; 安装 ♻️ 引入&am…

C++特殊类设计【特殊类 || 单例对象 || 饿汉模式 || 懒汉模式】

目录 一&#xff0c;特殊类设计 1. 只在堆上创建的类 2. 只允许在栈上创建的类 3. 不能被继承的类 4. 不能被拷贝的类 5. 设计一个类&#xff0c;只能创建一个对象&#xff08;单例对象&#xff09; 饿汉模式 懒汉模式 C11静态成员初始化多线程安全问题 二&#xff…

实现微服务:匹配系统

HTTP与WebSocket协议 1. HTTP协议是无状态的&#xff0c;每次请求都是独立的&#xff0c;服务器不会保存客户端的状态信息。而WebSocket协议是有状态的&#xff0c;一旦建立连接后&#xff0c;服务器和客户端可以进行双向通信&#xff0c;并且可以保持连接状态&#xff0c;服务…

谈谈你对Java平台的理解?

从你接触 Java 开发到现在&#xff0c;你对 Java 最直观的印象是什么呢&#xff1f;是它宣传的 “Write once, run anywhere”&#xff0c;还是目前看已经有些过于形式主义的语法呢&#xff1f;你对于 Java 平台到底了解到什么程度&#xff1f;请你先停下来总结思考一下。 今天…

【Qt】常用控件或属性(1)

需要云服务器等云产品来学习Linux可以移步/-->腾讯云<--/官网&#xff0c;轻量型云服务器低至112元/年&#xff0c;新用户首次下单享超低折扣。 目录 一、QWidget属性一览 二、控件button、属性enabled(可用状态) 三、属性geometry(修改位置和尺寸) 1、QRect类型的结…

mac系统下GCC优化编译的使用

mac系统下GCC优化编译的使用 编译流程 预处理&#xff1a;g -E homework.cpp -o homework.i 编译&#xff1a;g -S homework.i -o homework.s //.s为汇编文件 汇编&#xff1a;g -c homework.s -o homework.o 链接&#xff1a;g homework.o -o homework 优化选项 -O0&#…

4G安卓核心板T310_紫光展锐平台方案

紫光展锐T310应用 DynamlQ架构 12nm 制程工艺&#xff0c;采用 1*Cortex-A753*Cortex-A55处理器&#xff0c;搭载Android11.0操作系统&#xff0c;主频最高达2.0GHz.此外&#xff0c;DynamlQ融入了AI神经网络技术&#xff0c;新增机器学习指令&#xff0c;让其在运算方面的机器…

软件设计师17--磁盘管理

软件设计师17--磁盘管理 考点1&#xff1a;存储管理 - 磁盘管理调度算法磁盘调度 - FCFS磁盘调度 - SSTF例题&#xff1a; 考点1&#xff1a;存储管理 - 磁盘管理 存取时间寻道时间等待时间&#xff0c;训导时间是指磁头移动到磁道所需的时间&#xff1b;等待时间为等待读写的扇…

CC攻击详细

CC攻击是DDoS攻击的其中一种&#xff0c;是目前应用层攻击的主要手段之一&#xff0c;相比其它的DDoS攻击CC似乎更有技术含量一些。CC攻击借助代理服务器生成指向目标系统的合法请求&#xff0c;实现伪装和DDoS。我们都有这样的体验&#xff0c;访问一个静态页面&#xff0c;即…

笔记本的显示器都是核显输出,还要独显干啥呢?

前言 今天小白还在睡梦中&#xff0c;就接到一个朋友发来的消息&#xff1a;笔记本的显示器都是直接在核显上的&#xff0c;没有改独显的选项。 如果是这样&#xff0c;那笔记本还有独立显卡什么事情&#xff1f;笔记本加了独显难道就只是为了圈钱&#xff1f; 其实并不是这样…

Cassandra 集群安装部署

文章目录 一、概述1.官方文档2. 克隆服务器3.安装说明4.安装准备4.1.安装 JDK 114.2.安装 Python4.3.下载文件 二、安装部署1.配置 Cassandra2.启动 Cassandra3.关闭Cassandra4.查看状态5.客户端连接服务器6.服务运行脚本 开源中间件 # Cassandrahttps://iothub.org.cn/docs/m…