NOIP2012模拟试题【圆圈舞蹈( circle)
2.圆圈舞蹈( circle)
【问题描述】
熊大妈的奶牛在时针的带领下,围成了一个圆圈跳舞。由于没有严格的教育,奶牛们之间的间隔不一致。
奶牛想知道两只最远的奶牛到底隔了多远。奶牛A到B的距离为A顺时针走和逆时针走,到达B的较短路程。告诉你相邻两个奶牛间的距离,请你告诉奶牛两只最远的奶牛
到底隔了多远。
【输入】
第一行一个整数N,表示有N只奶牛。(2≤N≤100000)
接下来2~N+1行,第I行有一个数,表示第I-1头奶牛顺时针到第I头奶牛的距离。(1≤距离≤maxlongint,距离和≤maxlongint)
第N+l行的数表示第N头奶牛顺时针到第1头奶牛的距离。
【输出】
一行,表示最大距离。
【样例】
Circle.in
5
1
2
3
4
5
Circle.out
7
【样例解析】
Circle.out所有奶牛I到J之间的距离和到达方式(顺为顺时针,逆为逆时针)如下:
I\J |
1 |
2 |
3 |
4 |
5 |
1 |
O |
1 (顺) |
3(顺) |
6(顺) |
5(逆) |
2 |
1(逆) |
O |
2(顺) |
5(顺) |
6(逆) |
3 |
3(逆) |
2(逆) |
0 |
3(顺) |
7(顺) |
4 |
6(逆) |
5(逆) |
3(逆) |
0 |
4(顺) |
5 |
5(顺) |
6(顺) |
7(逆) |
4(逆) |
0 |
所以,最远的两头奶牛为3到5,距离是7。
分析样例(手写样例)时我们发现,最远距离总是接近圆圈周长的一半,对此我们可以证明
因为奶牛A到B的距离为A顺时针走(dis)和逆时针走(ddis),到达B的较短路程,逆时针走(ddis)等于圆圈周长(sum)减去顺时针走的路程(dis),所以最远距离即求 min(sum-dis,dis) 的最大值
什么时候最大?
显然,当dis最接近sum/2时。
因此我们只需要求得每个点的最远距离即可解答=v=
下面是寻找每个点的最远距离的过程
(蓝字表示dis)
首先是1号点(o゜▽゜)o☆
当到达4号点时,dis=6;当到达5号点时,dis=10;
因此又引出一个细节:因为我们寻找的总是折中的点,所以要比较它和它相邻的点分别到起点的距离;
距离1号点最远的是4号点
当寻找起点为2号点的最远距离时,简单的方法是将起点顺时针移动,如果距离未达到sum/2,就将终点也顺时针移动
寻找完后,dis=6-1+4=9,距离是6,与1号点的最远距离比较,最远距离不变依然为6
重复上述步骤,最终最远距离为起点是3号点,终点是5号点的距离,即7
(っ*´Д`)っ下面放出代码
#include<cstdio>
#include<cstring>
#include<cmath>
#include<ctime>
#include<algorithm>
using namespace std;
int n;
long long sum;
long long l[];
long long dis;
void work()
{
int u=;
int v=;
dis=;
long long ans=;
int j;
for(int i=;i<=n;i++)//寻找距离一号点最远的点
{
dis+=l[i-];//***
if(dis>sum/)
{
j=i;//记录这个点
break;
}
}
ans=max(ans,min(sum-dis,dis));//因为我们寻找的是折中的点,所以需要比较两次,即它和它相邻的点;
ans=max(ans,min(dis-l[j-],sum-dis+l[j-]));
for(int i=;i<=n;i++)
{
dis=dis-l[i-];//寻找第i个点的最远距离,将起点从上一个点顺时针移动
while(dis<sum/)
{
dis+=l[j+];
j++;//终点也顺时针移动
}
ans=max(ans,min(sum-dis,dis));//与上面同理
ans=max(ans,min(sum-dis+l[j-],dis-l[j-]));
}
printf("%lld ",ans);
}
void read()
{
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%lld",&l[i]);
sum+=l[i];//记录圆圈周长
}
}
int main()
{
freopen("circle.in","r",stdin);
freopen("circle.out","w",stdout);
//clock_t start=clock();
read();
work();
//clock_t end=clock();
//printf("%d %d",start,end);
return ;
}
F$PVDSR85.png)
F$PVDSR85.png)
F$PVDSR85.png)
NOIP2012模拟试题【圆圈舞蹈( circle)的更多相关文章
- NOIP2012模拟试题【奶牛晒衣服】
1.奶牛晒衣服(dry) [问题描述] 在熊大妈英明的带领下,时针和它的同伴生下了许多牛宝宝.熊大妈决定给每个宝宝都穿上可爱的婴儿装.于是,为牛宝宝洗晒衣服就成了很不爽的事情. 圣人王担负起了这个重任 ...
- NOIP2012模拟试题 121105【奶牛排队(tahort)
3.奶牛排队(tahort) [ 问题描述] 奶牛在熊大妈的带领下排成了一条直队. 显然,不同的奶牛身高不一定相同…… 现在,奶牛们想知道,如果找出一些连续的奶牛,要求最左边的奶牛A是最矮的,最右边的 ...
- 冲刺NOIP2015提高组复赛模拟试题(五)2.道路修建
2.道路修建 描述 Description liouzhou_101最悲痛的回忆就是NOI2011的道路修建,当时开了系统堆栈,结果无限RE… 出于某种报复心理,就把那题神奇了一下: 在 Z星球上有N ...
- 模拟试题C
模拟试题C 一.单项选择题(2′*14 =28′) 1.双线性法向插值法(Phong Shading)的优点是( ) A)法向计算精确 B)高光域准确 C)对光源和视点没有限制 D)速度较快 2.用编 ...
- 模拟试题B
模拟试题B 一.单项选择题(2′*8 =16′) 1.灰度等级为256级,分辨率为2048*1024的显示器,至少需要的帧缓存容量为( ) A)512KB B)1MB C)2MB D)3MB 2.在多 ...
- 模拟试题A
模拟试题A 一.单项选择题(2′*12=24′) 1.下面各种坐标变换中,会产生变换前后维度的改变的是( ) A)建模变换 B)观察变换 C)投影变换 D)视口变换 2.下列描述深度缓冲消隐算法的特点 ...
- CCF 模拟试题——出现次数最多的数 官方答案解析及自己写的正确答案
前几天知道的CCF计算机职业资格认证考试,觉得好像比软考含金量高一些,就去了解了一下,做了模拟试题中的 “出现次数最多的数” 这道题,我的算法和官方答案算法不同,个人觉得觉得官方的好一点,没那么繁琐, ...
- 【NOIP2012模拟8.7】JZOJ2020年8月8日提高组T1 奶牛编号
[NOIP2012模拟8.7]JZOJ2020年8月8日提高组T1 奶牛编号 题目 作为一个神秘的电脑高手,Farmer John 用二进制数字标识他的奶牛. 然而,他有点迷信,标识奶牛用的二进制数字 ...
- 9.29noip模拟试题
环上的游戏(cycle) 有一个取数的游戏.初始时,给出一个环,环上的每条边上都有一个非负整数.这些整数中至少有一个0.然后,将一枚硬币放在环上的一个节点上.两个玩家就是以这个放硬币的节点为起点开始这 ...
随机推荐
- DSP TMS320C6000基础学习(1)——介绍
主要内容 1. Why process signals digitally? (1)模拟电路由模拟组件构成:电阻.电容及电感等,这些组件随着电压.温度或机械结构的改变会动态影响到模拟电路的效果: (2 ...
- 【DFS+小操作判重】【HDU2610+HDU2611】Sequence
题意 2610 按照长度优先 位置次之 输出所有不递减序列 2611 按照长度优先 大小次之 输出所有不递减序列 题解不写了 来源于http://www.cnblogs.com/wally/archi ...
- Position详解---转
position有四个属性值: relative absolute fixed static 下面分别讲述这四个属性. 1. relative relative属性,相对定位,我们要搞清它是相对哪个对 ...
- SSH框架常会出现的一些错误
1.jquery datatable插件报JSON数据错误 错误原因:hql语句拼接有问题,前一个字符串与后一个字符串之间缺少空格,导致数据库查询失败. 2.addInput页面中input内容不为空 ...
- hdu1358Period
Problem Description For each prefix of a given string S with N characters (each character has an ASC ...
- oracle11g用户名密码不区分大小写
oracle 11g 以前的版本的用户名和密码是不区分大小写的; oracle 11g 用户名和密码默认区分大小写,可更改alter system set sec_case_sensitive_log ...
- your local changes would be overwritten by merge. commit stash or revert them to proceed. view them
error log: your local changes would be overwritten by merge. commit stash or revert them to proceed. ...
- MySQL操作类的封装(PHP)
<?php class mysql{ /** * 报错函数 * * @param string $error */ function err($error){ die("对不起,您的操 ...
- Linux PCI网卡驱动的详细分析
学习应该是一个先把问题简单化,在把问题复杂化的过程.一开始就着手处理复杂的问题,难免让人有心惊胆颤,捉襟见肘的感觉.读Linux网卡驱动也是一 样.那长长的源码夹杂着那些我们陌生的变量和符号,望而生畏 ...
- struts2之动态方法调用(转)
转自:http://blog.csdn.net/longwentao/article/details/6940289 当我们访问一个Action时,默认是访问execute()方法,但当在一个Acti ...