Advertisement
Diene

Untitled

Jan 23rd, 2019
289
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
C++ 0.94 KB | None | 0 0
  1. #include <bits/stdc++.h>
  2. using namespace std;
  3.  
  4. const int INF=0x3f3f3f3f;
  5. int memo[40][40][1000];
  6.  
  7. int dp(int n, int m, int k){
  8.     if(memo[n][m][k]<INF) return memo[n][m][k];
  9.     if(k==n*m || k==0) return memo[n][m][k]=0;
  10.     else if(k>m*n) return memo[n][m][k]=INF/2;
  11.     else {
  12.         int h=INF,v=INF;
  13.         for(int i=1; i<=n-1; i++){
  14.             for(int j=0; j<=k; j++){
  15.                 int a;
  16.                 a=dp(n-i,m,k-j)+dp(i,m,j)+m*m;
  17.                 h=min(h,a);
  18.             }
  19.         }
  20.         for(int i=1; i<=m-1; i++){
  21.             for(int j=0; j<=k; j++){
  22.                 int b;
  23.                 b=dp(n,m-i,k-j)+dp(n,i,j)+n*n;
  24.                 v=min(v,b);
  25.             }
  26.         }
  27.         return memo[n][m][k]=min(h,v);
  28.     }
  29. }
  30.  
  31. int main(){
  32.  
  33.     int t,n,m,k;
  34.     memset(memo,63, sizeof(memo));
  35.     cin>>t;
  36.     for(int i=0;i<t;i++){
  37.         cin>>n>>m>>k;
  38.         printf("%d\n", dp(n,m,k));
  39.     }
  40.     return 0;
  41. }
Advertisement
Add Comment
Please, Sign In to add comment
Advertisement