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. 【MVC】Scripts.Render的用法

    一.配置BundleConfig.cs文件 1.首先要在App_Start 里面BundleConfig.cs 文件里面 添加要包含的css文件2.BundleConfig就是一个微软新加的 一个打包 ...

  2. linux命令绕过

    前言: 做ctf时常常会遇到一些正则匹配将一些linux命令给过滤掉,这里将总结一些针对性的绕过方式. 一.空格绕过: {cat,flag.txt} cat${IFS}flag.txt cat$IFS ...

  3. Vue项目中实现tab栏和步骤条的数据联动

    也就是tab栏切换步骤条随之变化 <template>   <div>     <!-- 面包屑导航  -->     <el-breadcrumb sepa ...

  4. PHP0002:PHP基础1

    PHP基础 一个表单同时提交get 和 post php保存数据到文件

  5. 2019版本kali linux-3 系统安装与基本调试

    本次的实验环境是: kali linux -3 kali linux 全版本地址: http://old.kali.org/kali-images/ 楼主的主系统是:kali linux  如果想学好 ...

  6. 本地连接mysql的url写法

    一.jdbc:mysql:///中三条斜杠(///) 第三个/代表什么? jdbc:mysql:///testdatabase等同于 jdbc:mysql://localhost:3306/testd ...

  7. 组件使用v-model、$listeners、.sync(区别于v-model的双向数据绑定)

    自定义组件 自定义组件的v-model 首先我们先说一下在自定义组件中使用v-model的必要条件 在自定义的组件中要有input(这里我们先不讨论单选复选框) 在自定义组件的模板对象中要有props ...

  8. 剑指offer-基础练习-增删节点-链表

    /* 链表基本操作: 插入节点和删除节点 */ /* 思路: 使用指向链表的头指针,这样在新插入节点后,头指针不会改变 */ struct ListNode{ int value; ListNode* ...

  9. [HNOI2009]图的同构记数

    题意 在所以置换下,本质不同的\(n\)阶图个数 做法 可以假想成\(K_n\),边有黑白两色,黑边存在于原图,白边存在于补图 由于\(n\le 60\),可以手算出拆分数不大,所以我们爆搜置换群 对 ...

  10. 小白月赛22 J : 计算 A + B

    J:计算 A + B 考察点 : 高精度,字符串 坑点 : 字符串中可能全是数字,或者 + 超过 1 个,需要进行特殊判断 析题得侃: 关于高精度的各种板子 Code: #include <ve ...