Advertisement
Malinovsky239

B (Region 2012)

Jan 21st, 2012
183
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 2.13 KB | None | 0 0
  1. #include <cstdio>
  2. #include <iostream>
  3. #include <string>
  4.  
  5. #define N 2005
  6. #define INF int(1e6)
  7.  
  8. using namespace std;
  9.  
  10. int dp[N][N][2][2], m, n, add[2][2][2], res;
  11. pair<int, int> from[N][N][2][2];
  12. string s = "GB", answer;
  13.  
  14. void ans(int pos, int pos2, int ind1, int ind2) {
  15.     if (pos > 1) {     
  16.         ans(pos - 1, from[pos][pos2][ind1][ind2].first, from[pos][pos2][ind1][ind2].second, ind1);         
  17.     }
  18.     answer += s[ind1];
  19. }
  20.  
  21. int main() {
  22.     freopen("table.in", "r", stdin);
  23.     freopen("table.out", "w", stdout);
  24.  
  25.     cin >> m >> n;
  26.  
  27.     add[0][1][0] = add[0][0][1] = add[1][0][0] = 1;
  28.  
  29.     for (int end1 = 0; end1 < 2; end1++)
  30.         for (int end2 = 0; end2 < 2; end2++) { 
  31.             for (int i = 0; i < m + n; i++)
  32.                 for (int i2 = 0; i2 <= m; i2++) {          
  33.                     for (int k = 0; k < 2; k++)
  34.                         for (int l = 0; l < 2; l++) {                              
  35.                             dp[i][i2][k][l] = -INF;        
  36.                         }              
  37.                 }              
  38.  
  39. //          cout << "_______________\n";
  40.  
  41.             for (int j = 0; j < 2; j++)
  42.                 for (int k = 0; k < 2; k++) {
  43.                     dp[1][j + k][j][k] = add[end1][end2][j] + add[end2][j][k];
  44. //                  fprintf(stdout, "dp[1][%d][%d][%d] = %d\n", j + k, j, k, dp[1][j + k][j][k]);
  45.             }
  46.  
  47.             for (int i = 2; i < m + n; i++)
  48.                 for (int i2 = 0; i2 <= m; i2++) {          
  49.                     for (int j = 0; j < 2; j++)
  50.                         for (int k = 0; k < 2; k++)
  51.                             for (int l = 0; l < 2; l++) {
  52.                                 int next = (l ? 1 : 0);
  53.                                 next += i2;
  54.  
  55.                                 if (dp[i][next][k][l] < dp[i - 1][i2][j][k] + add[j][k][l]) {
  56.                                     dp[i][next][k][l] = dp[i - 1][i2][j][k] + add[j][k][l];
  57. //                                  fprintf(stdout, "dp[%d][%d][%d][%d] = %d\n", i, next, k, l, dp[i][next][k][l]);
  58.                                     from[i][next][k][l] = make_pair(i2, j);
  59.                                 }  
  60.                             }              
  61.                 }              
  62.  
  63.                 if (dp[n + m - 1][m][end1][end2] > res) {
  64.                     res = dp[n + m - 1][m][end1][end2];
  65.                     answer = "";               
  66.                     ans(n + m - 1, m, end1, end2);
  67.                     answer += s[end2];
  68.                 }
  69.         }
  70.     cout << answer << endl;
  71.                                        
  72.  
  73.     return 0;
  74. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement