Problem F : Glenbow Museum

Problem F : Glenbow Museum

The famous Glenbow Museum in Calgary is Western Canada’s largest museum, with exhibits ranging from art to
cultural history to mineralogy. A brand new section is being planned, devoted to brilliant computer programmers just
like you. Unfortunately, due to lack of space, the museum is going to have to build a brand new building and relocate
into it.

The size and capacity of the new building differ from those of the original building. But the floor plans of both
buildings are orthogonal polygons. An orthogonal polygon is a polygon whose internal angles are either 90° or 270°.
If 90° angles are denoted as R (Right) and 270° angles are denoted as O (Obtuse) then a string containing only R and
O can roughly describe an orthogonal polygon. For example, a rectangle (Figure 1) is the simplest orthogonal
polygon and it can be described as RRRR (the angles are listed in counter-clockwise order, starting from any corner).
Similarly, a cross-shaped orthogonal polygon (Figure 2) can be described by the sequence RRORRORRORRO,
RORRORRORROR, or ORRORRORRORR. These sequences are called angle strings.
Problem F : Glenbow Museum_第1张图片 Problem F : Glenbow Museum_第2张图片
         Figure 1: A rectangle               Figure 2: A cross-shaped polygon
Of course, an angle string does not completely specify the shape of a polygon – it says nothing about the length of
the sides. And some angle strings cannot possibly describe a valid orthogonal polygon (RRROR, for example).

To complicate things further, not all orthogonal polygons are acceptable floor plans for the museum. A museum
contains many valuable objects, and these objects must be guarded. Due to cost considerations, no floor can have
more than one guard. So a floor plan is acceptable only if there is a place within the floor from which one guard can
see the entire floor. Similarly, an angle string is acceptable only if it describes at least one acceptable polygon. Note
that the cross-shaped polygon in Figure 2 can be guarded by someone standing in the center, so it is acceptable. Thus
the angle string RRORRORRORRO is acceptable, even though it also describes other polygons that cannot be
properly guarded by a single guard.

Help the designers of the new building determine how many acceptable angle strings there are of a given length.

Input
The input file contains several test cases. Each test case consists of a line containing a positive integer L (1≤L≤1000),
which is the desired length of an angle string.

The input will end with a line containing a single zero.

Output
For each test case, print a line containing the test case number (beginning with 1) followed by the number of
acceptable angle strings of the given length. Follow the format of the sample output.

Sample Input
4
6
0

Output for the Sample Input
Case 1: 1
Case 2: 6

    从一个所有边都平行于坐标系的多边形的任一顶点出发,逆时针遍历,记录每次经过的顶点处的转角,组成的字符串叫做angle string。求指定长度的angle string中,能表示至少一个星形多边形的串个数。 
    显然当l=2k+1时,解不存在;当l=2k时,设m=(l+4)/2,根据组合数的知识,所求结果为C(m,4)+C(m-1,4)。
400016  2009-04-24 04:51:44  Accepted  0.000  Minimum  19193  C++  4123 - Glenbow Museum
 1  #include  < iostream >
 2  using   namespace  std;
 3 
 4  typedef  long   long  LL;
 5  inline LL cal(LL n){              // C(n,4) 
 6       return  n * (n - 1 ) * (n - 2 ) * (n - 3 ) / 24 ;
 7  }
 8  int  main(){
 9       int  ca = 1 ;
10      LL n;
11       while (cin >> n,n){
12           if (n  &   1 )
13              cout << " Case  " << ca ++<< " " << 0 << endl;
14           else {
15              n = (n + 4 ) >> 1 ;
16              cout << " Case  " << ca ++<< " " << cal(n) + cal(n - 1 ) << endl;
17          }
18      }
19       return   0 ;
20  }

你可能感兴趣的:(Problem F : Glenbow Museum)