Advertisement
vermashubhang

HIST2 SPOJ

Oct 23rd, 2014
407
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 1.64 KB | None | 0 0
  1. #include<bits/stdc++.h>
  2.  
  3. using namespace std;
  4.  
  5. int main()
  6. {
  7.     while(1)
  8.     {
  9.         int N;
  10.         cin>>N;
  11.         if(N==0)
  12.             return 0;
  13.         long long fact[(1<<N)][N];
  14.         long long count[(1<<N)][N];
  15.         int A[N];
  16.         int i,j,k;
  17.         for(i = 0 ; i< N ; i++)
  18.             cin>>A[i];
  19.        
  20.         for(i=0 ; i< (1<<N) ; i++)
  21.             for(j=0 ; j< N ; j++)
  22.                 count[i][j]=fact[i][j] = 0;
  23.            
  24.         for (i= 0 ; i<N ; i++)
  25.         {
  26.             count[(1<<i)][i] = 1;
  27.             fact[(1<<i)][i] = 2*A[i]+2;
  28.         }
  29.        
  30.         for(i= 3 ; i< (1<<N)  ; i++)
  31.         {
  32.             for(j = 0 ; j<N ; j++)
  33.             {
  34.                 if(i&(1<<j))
  35.                 {
  36.                     long long int temp_max = 2*A[j]+2;
  37.                     long long int c = 0;
  38.                     for(k= 0 ; k < N ; k++)
  39.                     {
  40.                         if(((i - (1<<j))&(1<<k)) != 0)
  41.                         {
  42.                             if(A[j]<A[k])
  43.                             {
  44.                                 temp_max = max(temp_max,fact[i - (1<<j)][k] +2 );
  45.                             }
  46.                             else
  47.                             {
  48.                                 temp_max = max(temp_max,fact[i - (1<<j)][k] + 2*abs(A[k]-A[j])  +2 );
  49.                             }
  50.                         }
  51.                     }
  52.                     fact[i][j] = temp_max;
  53.                
  54.                     for(k= 0 ; k < N ; k++)
  55.                     {
  56.                         if(((i - (1<<j))&(1<<k)) != 0)
  57.                         {
  58.                             if(A[j]<A[k])
  59.                             {
  60.                                 if(fact[i - (1<<j)][k] +2 == temp_max)
  61.                                     count[i][j] += count[i - (1<<j)][k];
  62.                             }
  63.                             else
  64.                             {
  65.                                 if(fact[i - (1<<j)][k] + 2*abs(A[k]-A[j])  +2  == temp_max)
  66.                                     count[i][j] += count[i - (1<<j)][k];
  67.                             }
  68.                         }
  69.                     }
  70.                 }
  71.             }
  72.         }
  73.    
  74.         long long int mm = -1;
  75.         long long int sum = 0;
  76.    
  77.         long long int tt = mm;
  78.  
  79.         for(i = 0 ; i< N ; i++)
  80.         {
  81.             mm = max(mm , fact[(1<<N)- 1 ][i] );
  82.         }
  83.         for(i=0;i<N ;i++)
  84.         {
  85.             if(fact[(1<<N)- 1 ][i] == mm)
  86.                 sum+= count[(1<<N)- 1 ][i];
  87.         }
  88.         cout<<mm<<" "<<sum<<endl;
  89.     }
  90.     return 0;
  91. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement