zoukankan      html  css  js  c++  java
  • 圆圈舞蹈 题解

    圆圈舞蹈

    [问题描述]

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

    奶牛想知道两只最远的奶牛到底隔了多远。奶牛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

  • 相关阅读:
    一个经典的页面布局
    巧避new的一个原型设计模式
    讲解关于javascript的继承
    根据指定日期 算出该周的一周日期
    原型实现的一个观察者模式
    减少类之间的耦合性
    Android 代码下载
    (转)open gl 实例 demo vs2005 环境
    Tile editor 快捷键
    这是第一篇博客~
  • 原文地址:https://www.cnblogs.com/shadowland/p/5970536.html
Copyright © 2011-2022 走看看