POJ1390:方盒游戏,考点:动态规划变量设置

原题:http://poj.org/problem?id=1390

描述

(由于百练上没有这道题,但是这道题又很重要,我印象中老师讲了好一会儿,所以还是写一写,题目描述直接照搬讲义了)

POJ1390:方盒游戏,考点:动态规划变量设置

 

 

POJ1390:方盒游戏,考点:动态规划变量设置

 

 

 问题分析

POJ1390:方盒游戏,考点:动态规划变量设置

 

 

 解法

POJ1390:方盒游戏,考点:动态规划变量设置

POJ1390:方盒游戏,考点:动态规划变量设置

 

 

POJ1390:方盒游戏,考点:动态规划变量设置

 

 POJ1390:方盒游戏,考点:动态规划变量设置

 

POJ1390:方盒游戏,考点:动态规划变量设置

 

POJ1390:方盒游戏,考点:动态规划变量设置

 

 POJ1390:方盒游戏,考点:动态规划变量设置

 

 代码如下:

 1 #include <iostream>
 2 #include <cstring>
 3 #include <algorithm>
 4 using namespace std;
 5 const int M = 210;
 6 struct Segment {
 7     int color;
 8     int len;
 9 };
10 Segment segments[M];
11 int score[M][M][M];
12 int ClickBox(int i, int j, int len) {
13     if (score[i][j][len] != -1)
14         return score[i][j][len];
15     int result = (segments[j].len + len) *
16         (segments[j].len + len);
17     if (i == j)
18         return result;
19     result += ClickBox(i, j - 1, 0);
20     for (int k = i; k <= j - 1; ++k) {
21         if (segments[k].color != segments[j].color)
22             continue;
23         int r = ClickBox(k + 1, j - 1, 0);
24         r += ClickBox(i, k, segments[j].len + len);
25         result = max(result, r);
26     }
27     score[i][j][len] = result;
28     return result;
29 }
30 int main()
31 {
32     int T;
33     cin >> T;
34     for (int t = 1; t <= T; ++t) {
35         int n;
36         memset(score, 0xff, sizeof(score));
37         cin >> n;
38         int lastC = 0;
39         int segNum = -1;
40         for (int i = 0; i < n; ++i) {
41             int c;
42             cin >> c;
43             if (c != lastC) {
44                 segNum++;
45                 segments[segNum].len = 1;
46                 segments[segNum].color = c;
47                 lastC = c;
48             }
49             else segments[segNum].len++;
50         }
51         cout << "Case " << t << ": " << ClickBox(0, segNum, 0) << endl;
52     }
53     return 0;
54 }

 

 

 

 

 

POJ1390:方盒游戏,考点:动态规划变量设置

 

上一篇:CF1327F AND Segments


下一篇:Apache Druid的性能优化