CodeForces Round #287 Div.2
A. Amr and Music (贪心)
水题,没能秒切,略尴尬。
#include <cstdio>
#include <algorithm>
using namespace std; const int maxn = +;
int a[maxn], r[maxn], ans[maxn]; int cmp(int i, int j) { return a[i] < a[j]; } int main()
{
//freopen("in.txt", "r", stdin); int n, k;
scanf("%d%d", &n, &k);
for(int i = ; i < n; ++i) r[i] = i;
for(int i = ; i < n; ++i) scanf("%d", &a[i]);
sort(r, r + n, cmp);
int sum = , cnt = ;
for(int i = ; sum + a[r[i]] <= k && cnt < n; ++i)
{
sum += a[r[i]];
ans[cnt++] = r[i];
} printf("%d\n", cnt);
for(int i = ; i < cnt - ; ++i) printf("%d ", ans[i]+);
if(cnt) printf("%d\n", ans[cnt-]+); return ;
}
代码君
B. Amr and Pins (找规律)
题意:
给出一个圆的半径 和 圆心的始末位置。每次操作只能绕圆周上的点旋转若干角度。求该圆从初位置到末位置最少的操作次数。
分析:
不妨设圆的半径为r,圆心在原点处。
先看只旋转一次的情况,圆心所有可能位置构成的区域为 半径为2r的圆(除去圆心那点),也可理解为半径为(0, 2r]的圆环区域
再看第二次旋转,其区域为半径在(2r, 4r]的圆环区域。 //这个不容易画图,自行脑补一下好啦
以此类推。
算法:
所以我们可以先算出圆心始末位置间的距离d,然后根据d和直径2r的关系,最终答案为
#include <cstdio>
#include <cmath> int main()
{
//freopen("in.txt", "r", stdin); int r, x1, y1, x2, y2, ans;
scanf("%d%d%d%d%d", &r, &x1, &y1, &x2, &y2);
double d = sqrt((long long)(x1-x2)*(x1-x2) + (long long)(y1-y2)*(y1-y2));
ans = (int)ceil(d / 2.0 / r);
printf("%d\n", ans); return ;
}
代码君
C. Guess Your Way Out! (模拟 LCA)
题意:
有一个树高为h的完全二叉树 和 一个目标叶子节点, 给出一种遍历方式(LRLRLR...)
求在到达目标节点时,遍历节点的总数。(不包括目标节点)
具体参见原文Guess Your Way Out!
分析:

以官方题解中的图为例。自己最开始对这道题没什么想法,所以后面的分析相当于题解的翻译。=_=||
从树根开始走到最底端,到达节点X。
如果X刚好是目标节点E,则得到结果为树高h。
否则,找到X和E的 Least Common Ancestor (最小公共祖先)。在右子树遍历之前,一定会遍历完左子树中所有的节点 (图中用红色标出) ,从而退出,进入右子树。
所以在到达右子树之前共遍历sum[h1] + h - h1,其中sum[h1]表示树高为h1的完全二叉树的节点个数。
在进入右子树后,更新树高h、根节点编号、遍历的方向(L or R),重复刚才的过程。
#include <cstdio>
#include <vector>
#include <algorithm>
using namespace std; typedef long long LL; LL h, n, sum[], ans = ;
vector<LL> anc1; int main()
{
//freopen("in.txt", "r", stdin); for(int i = ; i <= ; ++i) sum[i] = (1LL << (i+)) - ;
scanf("%I64d%I64d", &h, &n);
n += sum[h-]; //转化成整个二叉树中的编号
LL x = n;
anc1.push_back(x); //目标节点的所有祖先
while(x != )
{
x /= ;
anc1.push_back(x);
}
//for(int i = 0; i < anc1.size(); ++i) printf("%I64d ", anc1[i]); LL node = ;
bool choice = false; //遍历防线(L or R) while(node != n)
{
vector<LL> anc2; //当前叶子节点X的祖先
for(int i = ; i < h; ++i)
{
anc2.push_back(node);
if(!choice) node = node * ; else node = node * + ;
choice = !choice;
}
if(n == node) { ans += h; break; }
anc2.push_back(node);
reverse(anc2.begin(), anc2.end());
//for(int i = 0; i < anc2.size(); ++i) printf("%I64d ", anc2[i]); for(int i = ; i <= h; ++i) if(anc1[i] == anc2[i])
{//find LCA
ans += sum[i-] + h - i + ;
h = i - ; //更新树高
node = anc2[i-];
if((anc2[i]<<) == node) //更新根节点的编号 及 遍历方向
{
node = anc2[i] * + ;
choice = false;
}
else
{
node = (anc2[i] << );
choice = true;
}
break;
}
} printf("%I64d\n", ans); return ;
}
代码君
CodeForces Round #287 Div.2的更多相关文章
- Codeforces Round #287 (Div. 2) E. Breaking Good 最短路
题目链接: http://codeforces.com/problemset/problem/507/E E. Breaking Good time limit per test2 secondsme ...
- 贪心 Codeforces Round #287 (Div. 2) A. Amr and Music
题目传送门 /* 贪心水题 */ #include <cstdio> #include <algorithm> #include <iostream> #inclu ...
- Codeforces Round #287 (Div. 2) C. Guess Your Way Out! 思路
C. Guess Your Way Out! time limit per test 1 second memory limit per test 256 megabytes input standa ...
- Codeforces Round #287 (Div. 2) C. Guess Your Way Out! 水题
C. Guess Your Way Out! time limit per test 1 second memory limit per test 256 megabytes input standa ...
- Codeforces Round #287 (Div. 2) B. Amr and Pins 水题
B. Amr and Pins time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...
- Codeforces Round #287 (Div. 2) A. Amr and Music 水题
A. Amr and Music time limit per test 1 second memory limit per test 256 megabytes input standard inp ...
- Codeforces Round #287 (Div. 2) E. Breaking Good [Dijkstra 最短路 优先队列]
传送门 E. Breaking Good time limit per test 2 seconds memory limit per test 256 megabytes input standar ...
- Codeforces Round #287 (Div. 2) D. The Maths Lecture [数位dp]
传送门 D. The Maths Lecture time limit per test 1 second memory limit per test 256 megabytes input stan ...
- codeforcfes Codeforces Round #287 (Div. 2) B. Amr and Pins
B. Amr and Pins time limit per test 1 second memory limit per test 256 megabytes input standard inpu ...
随机推荐
- 统计某一字段等于不同值的个数的sql语句(分享)
本文介绍下,用一条sql语句统计某一字段等于不同值的个数,方法很独特,有需要的朋友参考下. 表t,数据: id type001 1001 0002 1001 ...
- unity3d应用内分享(微信、微博等)的实现
问题:如何在unity3d的游戏中实现分享功能,如图 思路: 1.分享功能的实现方式有多种,较方便快捷的一种是直接调用android的API来调出系统的分享界面 2.unity3d里面调用androi ...
- Python本地化例子 - gettext 模块
关键字:Python 3.4,gettext,本地化,Localization OS:Windows 7,Mac 1. 创建一个locsample.py文件,文件内容如下,把所有需要本地化的字符串放到 ...
- win系统一键安装JDK和Tuxedo
@echo off title JDK和tuxedo环境变量设置 color 0a set /p inputTUX= [请输入你要设置的tuxedo的安装目录:] if /i "%input ...
- CentOS 6.5 安装与配置LAMP
准备工作: 1.配置防火墙,开启80端口.3306端口vi /etc/sysconfig/iptables-A INPUT -m state --state NEW -m tcp -p tcp --d ...
- UIApplication深入研究
我们偶尔会调用这个类的api来实现一些功能,但是这个类是iOS编程中很重要的一个概念,所以总结以下这个类的信息,不对的地方请留言. UIApplication的核心作用是提供了iOS程序运行期间的控制 ...
- 使用Yeoman搭建 AngularJS 应用 (8) —— 让我们搭建一个网页应用
原文地址:http://yeoman.io/codelab/write-app.html 创建一个新的模板来显示一个todo的列表 打开views/main.html 为了从一个干净的模板开始,删除m ...
- PAT-乙级-1010. 一元多项式求导 (25)
1010. 一元多项式求导 (25) 时间限制 400 ms 内存限制 65536 kB 代码长度限制 8000 B 判题程序 Standard 设计函数求一元多项式的导数.(注:xn(n为整数)的一 ...
- kafka.network.AbstractServerThread中的线程协作机制
这个虚类是kafka.network.Acceptor和kafka.network.Processor的父类,提供了一个抽象的Sever线程. 它的有趣之处在于为子类的启动和停止提供了线程间的协作机制 ...
- strip_tags() 函数剥去 HTML、XML 以及 PHP 的标签
定义和用法 strip_tags() 函数剥去 HTML.XML 以及 PHP 的标签. 语法 strip_tags(string,allow) 参数 描述 string 必需.规定要检查的字符串. ...