博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
圆圈舞蹈 题解
阅读量:4317 次
发布时间:2019-06-06

本文共 1996 字,大约阅读时间需要 6 分钟。

圆圈舞蹈

[问题描述]

熊大妈的奶牛在时针的带领下,围成了一个圆圈跳舞。由于没有严格的教育,奶牛们之间的间隔不一致。

奶牛想知道两只最远的奶牛到底隔了多远。奶牛A到B的距离为A顺时针走和逆时针走,到达B的较短路程。告诉你相邻两个奶牛间的距离,请你告诉奶牛两只最远的奶牛到底隔了多远。

[输入]

第一行一个整数N,表示有N只奶牛。(2<=N<=100000)

接下来2~N+1行,第i行有一个数,表示第i-1头奶牛顺时针到第i头奶牛的距离。

(1<=距离<=maxlongint,距离和<=maxlongint)

第N+1行的数表示第N头奶牛顺时针到第1头奶牛的距离。

[输出]

一行,表示最大距离

[样例]

circle.in

5

1

2

3

4

5

circle.out

7

[样例解析]

Circle.out所有奶牛i到j之间的距离和到达方式(顺为顺时针,逆为逆时针)如下:

 

1

2

3

4

5

1

0

1(顺)

3(顺)

6(顺)

5(逆)

2

1(逆)

0

2(顺)

5(顺)

6(逆)

3

3(逆)

2(逆)

0

3(顺)

7(顺)

4

6(逆)

5(逆)

3(逆)

0

4(顺)

5

5(顺)

6(顺)

7(逆)

4(逆)

0

 ——————————————————分割线—————————————————

 SOLUTION

 

朴素想法:枚举环上两点求距离,复杂度O ( n) , n =105时间无法承受。

改进想法:朴素想法有大量不必要的重复计算,乱搞一下,复杂度O( n ) .

 

1 #include "iostream" 2  3 using namespace std ; 4 typedef long long QAQ ;  5 const long long INF = 1000000000 ;  6 const int maxN = 1e5 + 1e3 ; 7  8 inline QAQ gmax ( QAQ x , QAQ y ) { return x > y ? x : y ; } 9 QAQ S[ maxN ] ;10 11 inline int INPUT ( ) {12         int x = 0 , f = 1 ; char ch = getchar ( ) ;13         while ( ch < '0' || '9' < ch ) { if ( ch == '-' ) f = -1 ; ch = getchar ( ) ; }14         while ( ch >= '0' && ch <= '9' ) { x = ( x << 1 ) + ( x << 3 ) + ch -'0' ; ch = getchar ( ) ; } 15         return x * f ;16 } 17 18 int main ( ) {19         freopen ( "circle.in" , "r" , stdin ) ;20         freopen ( "circle.out" , "w" , stdout ) ;21         int N = INPUT ( ) ;22         for ( int i=1 ; i<=N ; ++i ) {23                 S[ i ] = S[ i - 1 ] + INPUT ( ) ;24         }25         QAQ Ans = -INF ;26         int L = 1 , R = 1 ; 27         while ( L <= R && R <= N ) {28                 unsigned long long Dis = S[ R ] - S[ L ] ;29                 if ( ( Dis << 1 ) <= S[ N ] ) {30                         ++R ; Ans = gmax ( Dis , Ans ) ;31                 }32                 else {33                         ++L , Ans = gmax ( S[ N ] - Dis , Ans ) ;34                 }35         }36         cout << Ans << endl ;37         return 0 ;38 }
View Code

2016-10-17 17:24:49

转载于:https://www.cnblogs.com/shadowland/p/5970536.html

你可能感兴趣的文章
最短路径(SP)问题相关算法与模板
查看>>
js算法之最常用的排序
查看>>
Python——交互式图形编程
查看>>
经典排序——希尔排序
查看>>
团队编程项目作业2-团队编程项目代码设计规范
查看>>
英特尔公司将停止910GL、915GL和915PL芯片组的生产
查看>>
团队编程项目作业2-团队编程项目开发环境搭建过程
查看>>
Stax解析XML示例代码
查看>>
cookie
查看>>
二级图片导航菜单
查看>>
<Using parquet with impala>
查看>>
07-Java 中的IO操作
查看>>
uclibc,eglibc,glibc之间的区别和联系【转】
查看>>
Java魔法堂:找外援的利器——Runtime.exec详解
查看>>
mysql数据库存放路径
查看>>
TestNG(五)常用元素的操作
查看>>
解决 Visual Studio 点击添加引用无反应的问题
查看>>
通过镜像下载Android系统源码
查看>>
python字符串格式化 %操作符 {}操作符---总结
查看>>
windows 不能在 本地计算机 启动 Apache
查看>>