2018-2019 ACM-ICPC, Asia East Continent Finals

总体情况

本次训练共3小时20分钟,通过题数4。

解题报告

D. Deja vu of … Go Players

题意

\(A,B\)博弈,\(A\)有\(N\)堆石子,第\(i\)堆数量\(a_i\); \(B\)有\(M\)堆石子,第\(i\)堆数量\(b_i\)。每次每个人可以从自己拥有的石子堆中选取任意一堆并拿走任意正整数个石子。先拿完的人赢。求胜负情况。$N,M \leq 100, $ $a_i,b_i \leq 10^9, $ \(T \leq 100\)

题解

很显然贪心跑得快,只和堆数有关。根据\(N,M\)的大小关系决定胜负。

L. Eventual … Journey

题意

有\(n\)个点,\(m\)条双向边长度都是\(1\),同时点被分为两类,每类点可以花费\(1\)的代价到任何一个自己同类的点。对所有\(i\),求

\[\sum_{j=1}^n {dist(i \to j)}
\]

数据范围\(n,m \leq 10^5\)

题解

我们设\(d_i\)为点\(i\)与不同于自己类别的点直接相连的数量。设\(a_i\)为点\(i\)的类别,取值\(0\)或\(1\)。设\(s_i\)为第\(i\)类点的数量。设\(c_i\)为第\(i\)类点中有多少个点与另一类点有边直接相连。

对于任意的\(i\),如果

  • \(d_i > 0\),那么显然点\(i\)可以花费\(1\)的代价到任何一个自己同类的点,以及任何一个与自己直接相连的不同类的点,其余的点代价为\(2\),于是答案为

\[n-1+s_{1-a_i}-d_i
\]

  • \(d_i = 0\),那么显然点\(i\)可以花费\(1\)的代价到任何一个与自己同类的点,花费\(2\)的代价到另一类点中与\(i\)所在类别点集有边直接相连的点,花费\(3\)的代价到其余的点。于是答案为

\[3(n-1) - 2(s_i - 1) - c_{1-a_i}
\]

时间复杂度 \(O(n+m)\)

F. Interstellar … Fantasy

题意

给出三维欧几里得空间中两个点的坐标,求不经过一个给定球体的最短路长。

题解

稍作思考,发现如果两点连线段与球体不相交则为线段长,若相交,则答案必然为两线段和一弧的和。保留原来的线段并不是最优解,很容易发现,当两线段与球相切时最优。更准确地,整条路经一定在给定三个点确定的平面上,并且平面与球交出的圆与两条线段相切时就是最优解。

利用点积叉积和矢量定比分点讨论一下即可。

P3 delt=p-q;
db len=delt.abs();
db d=(cross(p-c,q-c).abs())/(len);
if(d<r) {
db d1=(p-c).abs(), d2=(q-c).abs();
db l1=sqrt(d1*d1-r*r), l2=sqrt(d2*d2-r*r);
db theta = acos(dot(p-c,q-c)/(d1*d2)) - acos(r/d1) - acos(r/d2); if(abs(((sqrt(d1*d1-d*d)+sqrt(d2*d2-d*d)))*d - (cross(p-c,q-c).abs()) ) < 1e-5) {
if(d<1e-5) {
if(dot(p-c,q-c)>0) cout<<setiosflags(ios::fixed)<<setprecision(10)<<len<<endl;
else cout<<setiosflags(ios::fixed)<<setprecision(10)<<r*theta + l1 + l2<<endl;
}
else cout<<setiosflags(ios::fixed)<<setprecision(10)<<r*theta + l1 + l2<<endl;
}
else cout<<setiosflags(ios::fixed)<<setprecision(10)<<len<<endl;
}
else cout<<setiosflags(ios::fixed)<<setprecision(10)<<len<<endl;

训练20191009 2018-2019 ACM-ICPC, Asia East Continent Finals的更多相关文章

  1. 2019 ACM/ICPC Asia Regional shanxia D Miku and Generals (二分图黑白染色+01背包)

    Miku is matchless in the world!” As everyone knows, Nakano Miku is interested in Japanese generals, ...

  2. 2018-2019 ACM-ICPC, Asia East Continent Finals I. Misunderstood … Missing(dp)

    题目链接: http://codeforces.com/gym/102056/problem/I 题意: 人物有l两个属性分别是$A,D$ 每个回合人物$A\pm D$ 每个回合有三个选择分别是: 1 ...

  3. 2018-2019 ACM-ICPC, Asia East Continent Finals部分题解

    C:显然每p2个数会有一个0循环,其中22 32 52 72的循环会在200个数中出现,找到p2循环的位置就可以知道首位在模p2意义下是多少,并且循环位置几乎是唯一的(对72不满足但可能的位置也很少) ...

  4. 2018-2019 ACM-ICPC, Asia East Continent Finals Solution

    D. Deja vu of … Go Players 签. #include <bits/stdc++.h> using namespace std; int t, n, m; int m ...

  5. 2016 ACM/ICPC Asia Regional Shenyang Online 1009/HDU 5900 区间dp

    QSC and Master Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) ...

  6. hdu 5444 Elven Postman(二叉树)——2015 ACM/ICPC Asia Regional Changchun Online

    Problem Description Elves are very peculiar creatures. As we all know, they can live for a very long ...

  7. (二叉树)Elven Postman -- HDU -- 54444(2015 ACM/ICPC Asia Regional Changchun Online)

    http://acm.hdu.edu.cn/showproblem.php?pid=5444 Elven Postman Time Limit: 1500/1000 MS (Java/Others)  ...

  8. 2015 ACM/ICPC Asia Regional Changchun Online HDU 5444 Elven Postman【二叉排序树的建树和遍历查找】

    Elven Postman Time Limit: 1500/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others)T ...

  9. hduoj 4710 Balls Rearrangement 2013 ACM/ICPC Asia Regional Online —— Warmup

    http://acm.hdu.edu.cn/showproblem.php?pid=4710 Balls Rearrangement Time Limit: 6000/3000 MS (Java/Ot ...

随机推荐

  1. Electron – 基础学习(2): 项目打包成exe桌面应用 之electron-packager

    项目创建完成,启动正常,接下来就是项目打包了.将测试Demo打包成exe桌面应用,点击exe文件,运行项目. 书接上文,创建项目有三种方式 Git拷贝.直接创建:通过electron社群提供的命令行工 ...

  2. css3元素如何扭曲、移位或旋转

    css3 transform 兼容性:IE10+ transform:rotate(deg) 正数为顺时针,负数为逆时针 <!DOCTYPE html> <html lang=&qu ...

  3. Jacoco收集单元测试、集成测试和系统功能测试覆盖率

    Jacoco收集单元测试.集成测试和系统功能测试覆盖率 2020-02-27  目录 1 安装版本2 被测系统代码示例3 收集单元测试覆盖率4 收集集成和功能测试覆盖率 代码覆盖率可在单元测试.系统测 ...

  4. 监听Ueditor的 iframe中的按键,按键组合事件(Ctrl+s)

    个人博客 地址:https://www.wenhaofan.com/a/20190716214214 监听按键事件 ueditor.ready(function() {     UE.dom.domU ...

  5. python 学习笔记之手把手讲解如何使用原生的 urllib 发送网络请求

    urllib.urlopen(url[,data[,proxies]]) : https://docs.python.org/2/library/urllib.html python 中默认自带的网络 ...

  6. ng--tolist说明

    起步 下载模板: git clone https://github.com/tastejs/todomvc-app-template.git --depth 1 初始化项目: ng new todom ...

  7. Python安装1 —— Python3.8的安装

    本文内容皆为作者原创,如需转载,请注明出处:https://www.cnblogs.com/xuexianqi/p/12377746.html 一:什么是Python解释器 解释器(英语:Interp ...

  8. ROS开发--在订阅话题的回调函数中发布话题

    处理激光数据时,需要将处理后的激光数据再发布,需要保持一致的频率,所以必须在回调函数中发布激光数据信息. 代码参考:https://blog.csdn.net/heyijia0327/article/ ...

  9. PHPstorm主题、插件等相关推荐

    自己想升级PHPstorm,但是一直升级不了,捣腾一下午,终于它over掉了. 重新下载安装,发现应该把自己喜欢的插件.主题配色等记录一下. material theme UI主题插件 不知道为啥,看 ...

  10. java学习笔记之反射—Class类实例化和对象的反射实例化

    反射之中所有的核心操作都是通过Class类对象展开的,可以说Class类是反射操作的根源所在,但是这个类的实例化对象,可以采用三种方式完成. java.lang.Class类的定义: public f ...