URAL题解三
URAL题解三
URAL 1045
题目描述:有\(n\)个机场,\(n-1\)条航线,任意两个机场有且只有一种方案联通。现有两个恐怖分子从\(m\)号机场出发,第一个人在机场安装炸弹,乘坐飞机,引爆炸弹,在另一个机场降落,然后到第二人做一样的事,轮流做,直到某个人做不到就输。一个机场炸了后,任何与它相连的航线都不复存在。问第一个人能不能赢,如果能,则输出他第一个要飞到的机场,如果不能则输出First player loses
solution
博弈论,输赢状态的搜索。
时间复杂度:\(O(n)\)
URAL 1046
题目描述:在平面上有一个多边形,顶点坐标为\(A_i\)(顺时针),在多边形的每条边的外侧作一个点\(M_i\),使得\(M_i\)与对应边的两个点组成一个等腰三角形(对应边为底边),给出\(M_i\)和对应三角形顶角的角度\(\alpha _i\),求\(A_i\)。
solution
一开始不知道等腰有什么用,下意识就想去几何关系了。后来才想到:如果把\(M_i\)看成圆心,腰看成半径,那对应边的两个点都在圆上,也就是说,这两个点可以通过绕着\(M_i\)旋转一定角度得到,而这个角度就是\(\alpha _i\)。列出两条方程,发现未知数都是一次方的,可以用高斯消元解出所有未知数。
时间复杂度:\(O((2n)^3)\)
URAL 1047
题目描述:有\(n+2\)个数,\(a_0, a_1, ..., a_{n+1}\), 当\(1 \leq i \leq n\)时,\(a_i=(a_{i-1}+a_{i+1})/2-c_i\),给出\(a_0, a_{n+1}, c_i\),求\(a_1\)。
solution
一开始我又蠢蠢地去推公式,想直接算出答案。后来从问的结果得到灵感:不是只要求\(a_1\)吗?如果我能将\(a_{n+1}\)与\(a_0, a_1\)的关系递推出来,问题就解决了。整理一下公式
\[a_i=2(a_{i-1}+c_{i-1})-a_{i-2}\]
把每个\(a_i\)都表示为\(a_i=pa_0+qa_1+m\),最终就可以求出\(a_{n+1}\),解出答案。
时间复杂度:\(O(n)\)
URAL 1048
题目描述:给出两个\(n\)位数,求两个数的和。
solution
高精度,只是要注意一定要输出\(n\)位。
时间复杂度:\(O(n)\)
URAL 1049
题目描述:给出\(10\)个数,求这\(10\)个数的乘积的因数个数的个位。
solution
设\(10\)个数的乘积的质因子有\(m\)个,每个质因子有\(s_i\)个,那么因数个数就是\(\prod_{i=1}^m (s_i+1)\)。所以把这\(n\)个数的质因子个数统计一下即可。
时间复杂度:\(O(10\sigma(10^4))\)
URAL 1050
题目描述:给出很多段落,每个段落进行如下处理:从左到右找出双引号(")对(不一定相邻),将前一个双引号变成两个左单引号(`),将后一个双引号变成两个右单引号('),如果不成一对,则删去单独的双引号。注意:(\)后面紧接着的非字母字符串中的双引号不作处理(即找双引号时将其忽略)。
输出最终的段落。
solution
本来想一边读入一边处理,后来发现这样太恶心了,干脆就将它们一次过全部读进来,再对不同段落,是否结束,是否忽略进行判断,这样就舒服多了。
时间复杂度:\(O(总长度)\)
URAL 1051
题目描述:有一个无限网格,其中有一个\(n*m\)的石头矩形,石头放在网格中。现在可以任选一个石头,如果它四相邻的某个格子上有石头,则它可以往该方向跳两格,吃掉(移走)越过的石头,任意时刻一个格子中不能有多个石头。问最终最少剩下多少个石头。
solution
假设\(n \leq m\),当\(n<3\)时,显然答案是\((m+1)/2\)。
当\(n\)或\(m\)为\(3\)的倍数,则按下图进行处理:
所以答案是2.
当\(n>3\)且\(n\)不是\(3\)的倍数时,
先处理\(4*4, 5*5, 4*5\)
其它情况先三个三个地消除(像最上面第一个图),最后消成\(4\)或\(5\)行,然后用下面两个方法消列,最终变成\(4*4\)或\(5*5\)或\(4*5\)
所以答案是1.
URAL 1052
题目描述:在平面上有\(n\)个点,在平面上随意画一条直线,问最多穿过多少个点。
solution
两点确定一条直线,枚举两个点,再统计有多少个点在线上。
时间复杂度:\(O(n^3)\)
URAL题解三的更多相关文章
- URAL题解一
URAL题解一 URAL 1002 题目描述:一种记住手机号的方法就是将字母与数字对应,如图.这样就可以只记住一些单词,而不用记住数字.给出一个数字串和n个单词,用最少的单词数来代替数字串,输出对应的 ...
- UVA题解三
UVA题解三 UVA 127 题目描述:\(52\)张扑克牌排成一列,如果一张牌的花色或者数字与左边第一列的最上面的牌相同,则将这张牌移到左边第一列的最上面,如果一张牌的花色或者数字与左边第三列的最上 ...
- URAL题解二
URAL题解二 URAL 1082 题目描述:输出程序的输入数据,使得程序输出"Beutiful Vasilisa" solution 一开始只看程序的核心部分,发现是求快排的比较 ...
- URAL题解—不断跟新中
1014:简单题,忘了0的情况可以是10,== 1219:找呀找规律,满足N*(N-1)/2+1=X;就是1 的情况了
- Codeforces 1215D Ticket Game 题解
Codeforces 1215D Ticket Game 原题 题目 Monocarp and Bicarp live in Berland, where every bus ticket consi ...
- 收集一些关于OI/ACM的奇怪的东西……
一.代码: 1.求逆元(原理貌似就是拓展欧几里得,要求MOD是素数): int inv(int a) { if(a == 1) return 1; return ((MOD - MOD / a) * ...
- 【线段树】Bzoj1798 [AHOI2009] 维护序列
Description 老师交给小可可一个维护数列的任务,现在小可可希望你来帮他完成. 有长为N的数列,不妨设为a1,a2,…,aN .有如下三种操作形式: (1)把数列中的一段数全部乘一个值; (2 ...
- WC2019 题目集
最近写的一些 WC2019 上讲的一些题.还是怕忘了,写点东西记录一下. LOJ2983 「WC2019」数树 题意 本题包含三个问题: 问题 0:已知两棵 \(n\) 个节点的树的形态(两棵树的节点 ...
- BZOJ4543 Hotel加强版
题面 $\text{BZOJ}$间接权限题 洛谷的弱化版 题解 三点距离两两相等要满足以下条件: 有一个相同的$\text{LCA}$ 所以如果存在一个点,使得另外两个点在它子树中,距离为$d$,且$ ...
随机推荐
- iOS 监听键盘高度,输入框上升
//设置输入框 ---<因为输入框用了get方法,所以第一次调用输入框要用self 调用>: self.textlab.frame=CGRectMake(, , , ); _textlab ...
- 【Java】数据库查询的数据直接以指定文件类型下载到本地(弹出下载框)
欲实现的功能目标:当点击下图的导出数据文件时弹出文件下载框,默认csv格式,用户自定义下载的本地路径 遇到的问题: 1.项目之前做过一次下载,但是是使用了本地文件模板.用输入流读取文件模板,插入数据, ...
- 【ListBox】ListBox的相关操作
Winform中两个listbox的操作是平时比较常用的操作. 本次将以一个Winform实例来分享一下两个listbox的操作,包括:listbox添加项,项的上移下移等操作. 假设有两个listb ...
- 【BZOJ2436】【NOI2011】NOI嘉年华(动态规划)
[BZOJ2436]NOI嘉年华(动态规划) 题面 BZOJ 题解 考虑第一问如何求解 发现状态与选择了哪些活动无关,只与时间有关 设\(f[i][j]\)表示前\(i\)个单位时间(离散后),一个嘉 ...
- excel换行
在excel的单元格中换行 1. windows alt + enter 2. mac command + alt + enter
- 解题:AHOI 2013 作业
题面 emmm......我把莫队扔到了杂题里,因为感觉局限挺大的=.= 这题是莫队维护信息+分块查询答案,都是两者的基本操作,复杂度$O(m$ $sqrt(n)+n$ $sqrt(m))$ 所以为啥 ...
- [ZJOI2011]细胞——斐波那契数列+矩阵加速+dp
Description bzoj2323 Solution 题目看起来非常复杂. 本质不同的细胞这个条件显然太啰嗦, 是否有些可以挖掘的性质? 1.发现,只要第一次分裂不同,那么互相之间一定是不同的( ...
- poj 1945 Power Hungry Cows A*
Description: 就是给你一个数,你可以把它自乘,也可以把他乘或除以任意一个造出过的数,问你最多经过多少次操作能变换成目标数 思路:这题真的不怎么会啊.n = 20000,每一层都有很 ...
- VirtualBox安装虚拟机全过程
使用Virtual Box安装虚拟机,虚拟机操作系统使用CentOS7进行安装,安装完成后解决网络设置的问题. 一.虚拟机新建过程 1.点击新建. 2.设置内存大小,点击下一步. 3.选择虚拟硬盘,点 ...
- ios 逆向
Theos https://www.jianshu.com/p/307243ea40e4 Dumpsdecrypted https://www.cnblogs.com/wangyaoguo/p/908 ...