XX Russia Team Open, High School Programming Contest St Petersburg, Barnaul, Tbilisi, Almaty, Kremenchug, November 30, 2019
- easy: AFI
- medium-easy: BDH
- medium: CGKL
- ???: EJ
A. Attractive Flowers
签到。
B. Blocking the View
题意 问线段ab沿向量v移动是否会与线段cd相交
做法
- 把ac,ad,bc,bd四个向量排序一下,判断v是否在范围内就好
- 坑点在线段共线的情况
C. Fermat’s Last Theorem
题意 将有序四元组 \((a,b,c,n)\) 按 max 为第一关键字,字典序为第二关键字排序,求第 l 位到第 r 位,并判断 \(a^n+b^n\) 与 \(c^n\) 大小关系。
做法 先确定 max,后逐位考虑,可以求出 rank 为 \(x\) 的四元组是谁。如果 \((\frac{a}{c})^n+(\frac{b}{c})^n\) 和 1 的距离大于 eps,直接得出大小关系,否则高精度计算 \(a^n+b^n\) 与 \(c^n\) 大小关系。
D. Guess the Path
题意 交互,\(n*m\),每次可以输出一条 \((1,1)\) 到 \((n,m)\) 的路径(只能往右走或往下走),返回与既定路径 \(p\) 的交。
做法 如果 \((x_1,y_1), (x_2,y_2)(x_1 \leq x_2, y_1 \leq y_2)\) 在答案中,我们可以递归地构造 \((x_1,y_1)\) 到 \((x_2, y_2)\) 的路径。先右走到 \((x_1, (y_1+y_2)/2)\) 再下走到 \((x_2,(y_1+y_2)/2)\) 再右走,下走的过程和路径 \(p\) 必定有交。这样递归的层数是 log 级别的。
E. Hide-and-Seek for Robots
F. Isosceles triangles
做法
枚举等腰三角形顶点,正三角形会被算多次,减去。
G. Too Many Hyphens
题意 给一个 +- 组成的序列,现在需要插入一个极短的合法括号序列,使得任意两个 - 不相邻。求所有方案中字典序 \(k\) 小。
做法
- 如果有 \(x\) 对
-相邻,那么最短的括号序列,左括号个数是 \(\lceil \frac{x}{2} \rceil\) - \(f[i][j][k]\) 表示考虑第 \(0\) 个到第 \(i-1\) 个空隙中填入了 \(j\) 个
{, \(k\) 个},接下来有几种填写方式能够填出最优解。 - 决策的时候,枚举在当前空隙填啥,注意到填入的字符不超过 2 个。
H. Planet Nine
题意 两种操作,加 \(9x\),扔掉长度为 \(y\) 的全是 1 的前缀。把 \(a\) 变成 \(b\)
做法
- 因为 \(9|10^k-1\) 所以每次可以让一个低位减一,让一个高位加一。
- 先把 \(a\) 变成 0,再把 \(0\) 变成 \(b\)
I. Dates
签到
J. Factory
K. RotationAlmostSort
题意 n x n的格子,格子里有数字,一条指令是这样的:若格子a的数字>格子b的数字,则将以格子c为左上角的2*2的区域逆时针旋转90度,你需要用这样的指令使无论初始格子里的数字是啥,执行完毕之后从第三行开始把数字依次写下得到的序列是非减的
做法
- 可以用三条指令使一个2*2的区域里的最大值移动到这个区域里的任意位置
- 用这种操作每次选出最大值摆到对应位置
L. Time Travel
题意 给k棵大小为n的树,对于每个点对(u,v),求在每棵树的u到v的路径的点集的交集的大小
做法
- 一棵树中有\(dist(j,k)+dist(k,j)>=dist(i,j)\),等号取到当且仅当k在i到j的路径上
- 如果k对(i,j)有贡献,那么在每棵树中都要有\(dist(j,k)+dist(k,j)=dist(i,j)\)
- 比赛时哈希判断的,其实只需要判断\(\sum dist(j,k)+\sum dist(k,j)=\sum dist(i,j)\)就好了
- 因为都是大于等于号的不等式求和之后的不等式等号取到的条件肯定是每个不等式都取到等号吖
XX Russia Team Open, High School Programming Contest St Petersburg, Barnaul, Tbilisi, Almaty, Kremenchug, November 30, 2019的更多相关文章
- ACM ICPC 2010–2011, Northeastern European Regional Contest St Petersburg – Barnaul – Tashkent – Tbilisi, November 24, 2010
ACM ICPC 2010–2011, Northeastern European Regional Contest St Petersburg – Barnaul – Tashkent – Tbil ...
- zoj The 12th Zhejiang Provincial Collegiate Programming Contest Team Formation
http://acm.zju.edu.cn/onlinejudge/showContestProblem.do?problemId=5494 The 12th Zhejiang Provincial ...
- 2016-2017 ACM Central Region of Russia Quarterfinal Programming Contest
2016-2017 ACM Central Region of Russia Quarterfinal Programming Contest A. Fried Fish 题意:有N条鱼,有一个同时可 ...
- Codeforces Gym101572 B.Best Relay Team (2017-2018 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2017))
2017-2018 ACM-ICPC Nordic Collegiate Programming Contest (NCPC 2017) 今日份的训练,题目难度4颗星,心态被打崩了,会的算法太少了,知 ...
- ZOJ 3703 Happy Programming Contest
偏方记录背包里的物品.....每个背包的价值+0.01 Happy Programming Contest Time Limit: 2 Seconds Memory Limit: 65536 ...
- zoj The 12th Zhejiang Provincial Collegiate Programming Contest Capture the Flag
http://acm.zju.edu.cn/onlinejudge/showContestProblem.do?problemId=5503 The 12th Zhejiang Provincial ...
- zoj The 12th Zhejiang Provincial Collegiate Programming Contest Demacia of the Ancients
http://acm.zju.edu.cn/onlinejudge/showContestProblem.do?problemId=5504 The 12th Zhejiang Provincial ...
- The Ninth Hunan Collegiate Programming Contest (2013) Problem L
Problem L Last Blood In many programming contests, special prizes are given to teams who solved a pa ...
- The Ninth Hunan Collegiate Programming Contest (2013) Problem C
Problem C Character Recognition? Write a program that recognizes characters. Don't worry, because yo ...
随机推荐
- python学习笔记:模块——自定义模块的3种导入方式
一.定义 模块就是用一堆的代码实现了一些功能的代码的集合,通常一个或者多个函数写在一个.py文件里,而如果有些功能实现起来很复杂,那么就需要创建n个.py文件,这n个.py文件的集合就是模块.如果不懂 ...
- java 重新学习 (五)
Set 集合 一.HashSet按照Hash算法存储集合元素(hashCode方法获取hashCode值,根据hashCode值获取元素位置,通过equals判断对象是否相等并且hashCode值是否 ...
- 给Laravel4添加中文语系(转)
Laravel 4 官方不附带英文以外的 validataion 错误信息翻译. 今天发现GitHub 上有一个 repository 收集不同的翻译,大家可以下载需要的翻译. GitHub项目地址: ...
- 分布式-技术专区-Redis分布式锁实现-第二步
再上次篇章中汇集了相关的分布式锁的概念进行控制,接下来我们采用的是注解声明式开发服务方案,进行声明式开发代替编程式开发方案. 1.利用aop实现分布式锁2.只用在方法上加个注解,同时加上了重试机制 ...
- 使用python+ffmpeg批量转换格式
需求: 给定一个文件夹路径,遍历该文件夹内的所有文件以及子文件夹内的文件,当所有后缀名为wav格式的文件转换为ogg格式的文件. import os # 获取目录下的所有文件列表 import fn ...
- 【记录】VScode快捷键大全
记住快捷键能够提高工作效率 Ctrl+Shift+P,F1 展示全局命令面板 Ctrl+P 快速打开最近打开的文件 Ctrl+Shift+N 打开新的编辑器窗口 Ctrl+Shift+W 关闭编辑器 ...
- python使用SMTP发邮件时使用Cc(抄送)和Bcc(密送)
SMTP发送邮件的时候,并没有特殊的通信语句告诉邮件服务器 谁是主送,谁是抄送/密送,这三个角色都是以同样的方式告诉邮件服务器的,然后重点在邮件内容里. 邮件内容分为头和体两部分(就像http),头部 ...
- celery中配置redis密码时的ValueError: invalid literal for int() with base 10: 'xxxx'
原配置: celery_broker = 'redis://:xxxx#xxxx@172.17.0.1:6379/0' # docker0 错误原因: 密码中不能有 # ? 等特殊字符 (无语O__O ...
- 创建win32 dll 空项目
动态库,多字节 win32 空项目 添加导出头文件 类 导入: #pragma once #ifndef IP_CLASS_DLL_H #define IP_CLASS_DLL_H #pragma ...
- ubtuntu下虚拟环境搭建【python】
为什么要搭建虚拟环境? 在开发过程中, 当需要使用python的某些工具包/框架时需要联网安装 比如联网安装Flask框架flask-0.10.1版本 sudo pip install flask== ...