补题链接:Here

A - 2nd Greatest Distance

二维坐标图中有 \(n\) 个房子,现在规定两房子距离定义为: \(max(|x_i−x_j|,|y_i−y_j|)\)

求第二大的距离值


【解法一】对 \(x,y\) 进行排序寻找

#define f first
#define s second
const int N = 2e5 + 10;
pair<int, int>x[N], y[N];
int n;
void solve() {
cin >> n;
for (int i = 1; i <= n; i++)
cin >> x[i].f >> y[i].f, x[i].s = y[i].s = i;
sort(x + 1, x + 1 + n);
sort(y + 1, y + 1 + n);
int t = (x[n].s == y[n].s && x[1].s == y[1].s ? 0 : min(x[n].f - x[1].f, y[n].f - y[1].f));
cout << max(x[n].f - x[2].f, max(x[n - 1].f - x[1].f, max(y[n].f - y[2].f, max(y[n - 1].f - y[1].f, t))));
}

【解法二】官方题解

我们没有时间计算 \(\frac{N(N - 1)}{2}\) 个距离中的每一个,并在 \(O(N^2log N)\) 时间内对它们进行排序。

这里要更多地利用距离的属性。 考虑找出以下问题:

  • 两所房子 x 坐标的最大差异 两所房子 y 坐标的最大差异
  • 两所房子 x 坐标的第二大差异 两所房子 y 坐标的第二大差异

我们可以很容易地 找出它们中的前两个,x 坐标的第二大差异是以下之一:

  • 第二大 x 坐标减去最小的 x 坐标 最大的 x 坐标减去第二小的 x 坐标 我们可以找到 y 坐标的第二大差异类似。

现在,我们可以只打印四个差异中的第二大值吗? 不幸的是,如果同一对房屋在其中出现两次,则可能是错误的。

为了解决这个问题,让我们列出出现在这四对中的所有房屋,并找出列表中每对房屋之间的距离。 由于列表最多包含 8 个房子,一个有效的实现将在 \(O (N)\) 时间内完成。

#define f first
#define s second
const int N = 2e5 + 10;
pair<int, int>x[N], y[N];
int n;
void solve() {
cin >> n;
for (int i = 1; i <= n; i++)
cin >> x[i].f >> y[i].f, x[i].s = y[i].s = i;
sort(x + 1, x + 1 + n);
sort(y + 1, y + 1 + n);
int t = (x[n].s == y[n].s && x[1].s == y[1].s ? 0 : min(x[n].f - x[1].f, y[n].f - y[1].f));
cout << max(x[n].f - x[2].f, max(x[n - 1].f - x[1].f, max(y[n].f - y[2].f, max(y[n - 1].f - y[1].f, t))));
}

B - RGB Matching

给狗狗按 R,G,B分组排序,如果是 3偶 则可以直接输出 \(0\) ,对于 1偶2奇

  • R 偶数,考虑 GB 的最小值在另一组的大小关系
  • G 偶数,考虑 RB 的最小值在另一组的大小关系
  • B 偶数,考虑 RG 的最小值在另一组的大小关系
#include<bits/stdc++.h>
#define int long long
using namespace std;
int const N = 233333;
int n;
vector<int>dog[3];
int sub(vector<int>a, vector<int>b) {
int ans = 1e18;
for (int i = 0; i < a.size(); i++) {
int p = lower_bound(b.begin(), b.end(), a[i]) - b.begin();
if (p < b.size())ans = min(ans, abs(a[i] - b[p]));
if (p > 0)ans = min(ans, abs(a[i] - b[p - 1]));
}
return ans;
}
signed main() {
ios::sync_with_stdio(0);
cin >> n;
for (int i = 1; i <= 2 * n; i++) {
int x; char c;
cin >> x >> c;
switch (c) {
case'R': dog[0].push_back(x); break;
case'G': dog[1].push_back(x); break;
case'B': dog[2].push_back(x);break;
}
}
for (int i = 0; i < 3; i++)sort(dog[i].begin(), dog[i].end());
int k0 = dog[0].size() % 2, k1 = dog[1].size() % 2, k2 = dog[2].size() % 2;
if (!k0 && !k1 && !k2) {cout << 0; return 0;}
int s01 = sub(dog[0], dog[1]), s02 = sub(dog[0], dog[2]), s12 = sub(dog[1], dog[2]);
if (!k0)cout << min(s12, s01 + s02);
if (!k1)cout << min(s02, s01 + s12);
if (!k2)cout << min(s01, s02 + s12);
return 0;
}

AtCoder Regular Contest 121 (AB题解)的更多相关文章

  1. AtCoder Regular Contest 121 D - 1 or 2

    题目链接:点我点我 Problem Statement Snuke has a blackboard and NN candies. The tastiness of the ii-th candy ...

  2. 2018.09.02 Atcoder Regular Contest 102简要题解

    比赛传送门 T1 Triangular Relationship 分析之后发现有两种情况: 1. n为奇数,那么所有数都是k的倍数. 2. n为偶数,那么所有数都是k/2的倍数. 然后就可以愉快A题了 ...

  3. AtCoder Regular Contest 094 (ARC094) CDE题解

    原文链接http://www.cnblogs.com/zhouzhendong/p/8735114.html $AtCoder\ Regular\ Contest\ 094(ARC094)\ CDE$ ...

  4. AtCoder Regular Contest 096

    AtCoder Regular Contest 096 C - Many Medians 题意: 有A,B两种匹萨和三种购买方案,买一个A,买一个B,买半个A和半个B,花费分别为a,b,c. 求买X个 ...

  5. AtCoder Regular Contest 061

    AtCoder Regular Contest 061 C.Many Formulas 题意 给长度不超过\(10\)且由\(0\)到\(9\)数字组成的串S. 可以在两数字间放\(+\)号. 求所有 ...

  6. AtCoder Regular Contest 092

    AtCoder Regular Contest 092 C - 2D Plane 2N Points 题意: 二维平面上给了\(2N\)个点,其中\(N\)个是\(A\)类点,\(N\)个是\(B\) ...

  7. AtCoder Regular Contest 093

    AtCoder Regular Contest 093 C - Traveling Plan 题意: 给定n个点,求出删去i号点时,按顺序从起点到一号点走到n号点最后回到起点所走的路程是多少. \(n ...

  8. AtCoder Regular Contest 094

    AtCoder Regular Contest 094 C - Same Integers 题意: 给定\(a,b,c\)三个数,可以进行两个操作:1.把一个数+2:2.把任意两个数+1.求最少需要几 ...

  9. AtCoder Regular Contest 095

    AtCoder Regular Contest 095 C - Many Medians 题意: 给出n个数,求出去掉第i个数之后所有数的中位数,保证n是偶数. \(n\le 200000\) 分析: ...

  10. AtCoder Regular Contest 102

    AtCoder Regular Contest 102 C - Triangular Relationship 题意: 给出n,k求有多少个不大于n的三元组,使其中两两数字的和都是k的倍数,数字可以重 ...

随机推荐

  1. Python读取Ansible playbooks返回信息

    一.背景及概要设计 当公司管理维护的服务器到达一定规模后,就必然借助远程自动化运维工具,而ansible是其中备选之一.Ansible基于Python开发,集合了众多运维工具(puppet.chef. ...

  2. IDEA 激活码全家桶 webStorm亲测可用【更新日期2021.11.30】

    3MRUAPM31O-eyJsaWNlbnNlSWQiOiIzTVJVQVBNMzFPIiwibGljZW5zZWVOYW1lIjoi5rC45LmF5r+A5rS7IHd3d8K3YWppaHVvw ...

  3. Maven仓库settings.xml配置信息

    找到你的settings.xml配置文件E:\maven3.6.3\apache-maven-3.6.3\conf # 你的本地依赖仓库路径 <localRepository>E:\mav ...

  4. Semantic Kernel 正式发布 v1.0.1 版本

    微软在2023年12月19日在博客上(Say hello to Semantic Kernel V1.0.1)发布了Semantic kernel的.NET 正式1.0.1版本.新版本提供了新的文档, ...

  5. GIS系统想要实现Cesium For Unreal的视觉效果是否有捷径可走?

    对于大多数GIS开发人员来说,CesiumJS都是比较熟悉的引擎,但是相比较Cesium For Unreal而言,CesiumJS的视觉效果就显得差强人意了,因此一些GIS开发人员对Cesium F ...

  6. NC65二开经验总结

    公式相关 1.显示公式没执行 列表界面显示,卡片界面不显示: Handler的onBoCard执行: getBillCardPanel().execHeadLoadFormulas(); Contro ...

  7. 解决 IDEA 报错ERROR:JAVA: 无效的源发行版: 11

    解决 IDEA 报错ERROR:JAVA: 无效的源发行版: 11 原因 一般都是创建工程的时候 一路next 默认选择了 Java Version 11, 而本地的jdk版本是 8 解决 File ...

  8. ACTF flutter逆向学习

    参考了许多大佬的博客,在此特别诚挚感谢oacia大佬和其他大佬的博客和指导! 1.flutter和apk基础结构介绍 首先下载附件,是一个apk文件,用jadx打开 可以看见flutter字样,而fl ...

  9. Mysql索引失效的几种原因-mysql-suo-yin-shi-xiao-de-ji-zhong-yuan-yin

    title: Mysql索引失效的几种原因 date: 2021-07-15 17:13:59.019 updated: 2021-12-26 17:43:12.489 url: https://ww ...

  10. 【WALT】调度与负载计算(未更新完)

    [WALT]调度与负载计算 代码版本:Linux4.9 android-msm-crosshatch-4.9-android12 注:本文中的任务主要指进程. @ 目录 [WALT]调度与负载计算 一 ...