codeforces 598E E. Chocolate Bar(区间dp)
2016-03-21 22:30
471 查看
题目链接:
E. Chocolate Bar
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output
You have a rectangular chocolate bar consisting of n × m single squares. You want to eat exactly k squares, so you may need to break the chocolate bar.
In one move you can break any single rectangular piece of chocolate in two rectangular pieces. You can break only by lines between squares: horizontally or vertically. The cost of breaking is equal to square of the break length.
For example, if you have a chocolate bar consisting of 2 × 3 unit squares then you can break it horizontally and get two 1 × 3 pieces (the cost of such breaking is 32 = 9), or you can break it vertically in two ways and get two pieces: 2 × 1 and 2 × 2 (the cost of such breaking is 22 = 4).
For several given values n, m and k find the minimum total cost of breaking. You can eat exactly k squares of chocolate if after all operations of breaking there is a set of rectangular pieces of chocolate with the total size equal to k squares. The remaining n·m - ksquares are not necessarily form a single rectangular piece.
Input
The first line of the input contains a single integer t (1 ≤ t ≤ 40910) — the number of values n, m and k to process.
Each of the next t lines contains three integers n, m and k (1 ≤ n, m ≤ 30, 1 ≤ k ≤ min(n·m, 50)) — the dimensions of the chocolate bar and the number of squares you want to eat respectively.
Output
For each n, m and k print the minimum total cost needed to break the chocolate bar, in order to make it possible to eat exactly ksquares.
Examples
input
output
Note
In the first query of the sample one needs to perform two breaks:
to split 2 × 2 bar into two pieces of 2 × 1 (cost is 22 = 4),
to split the resulting 2 × 1 into two 1 × 1 pieces (cost is 12 = 1).
In the second query of the sample one wants to eat 3 unit squares. One can use exactly the same strategy as in the first query of the sample.
AC代码:
E. Chocolate Bar
time limit per test
2 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output
You have a rectangular chocolate bar consisting of n × m single squares. You want to eat exactly k squares, so you may need to break the chocolate bar.
In one move you can break any single rectangular piece of chocolate in two rectangular pieces. You can break only by lines between squares: horizontally or vertically. The cost of breaking is equal to square of the break length.
For example, if you have a chocolate bar consisting of 2 × 3 unit squares then you can break it horizontally and get two 1 × 3 pieces (the cost of such breaking is 32 = 9), or you can break it vertically in two ways and get two pieces: 2 × 1 and 2 × 2 (the cost of such breaking is 22 = 4).
For several given values n, m and k find the minimum total cost of breaking. You can eat exactly k squares of chocolate if after all operations of breaking there is a set of rectangular pieces of chocolate with the total size equal to k squares. The remaining n·m - ksquares are not necessarily form a single rectangular piece.
Input
The first line of the input contains a single integer t (1 ≤ t ≤ 40910) — the number of values n, m and k to process.
Each of the next t lines contains three integers n, m and k (1 ≤ n, m ≤ 30, 1 ≤ k ≤ min(n·m, 50)) — the dimensions of the chocolate bar and the number of squares you want to eat respectively.
Output
For each n, m and k print the minimum total cost needed to break the chocolate bar, in order to make it possible to eat exactly ksquares.
Examples
input
4 2 2 1 2 2 3 2 2 2 2 2 4
output
5 5 4 0
Note
In the first query of the sample one needs to perform two breaks:
to split 2 × 2 bar into two pieces of 2 × 1 (cost is 22 = 4),
to split the resulting 2 × 1 into two 1 × 1 pieces (cost is 12 = 1).
In the second query of the sample one wants to eat 3 unit squares. One can use exactly the same strategy as in the first query of the sample.
AC代码:
#include <bits/stdc++.h> using namespace std; const int inf=0x7f7f7f7f; int dp[32][32][53]; int n,m,k; int get_ans() { memset(dp,inf,sizeof(dp)); for(int i=0;i<=30;i++) { for(int j=0;j<=30;j++) { dp[i][j][0]=0; dp[0][i][j]=0; dp[i][0][j]=0; } } for(int i=1;i<=30;i++) { for(int j=1;j<=30;j++) { int x=min(i*j,50); if(i*j<=50)dp[i][j][i*j]=0; for(int k=1;k<=x;k++) { for(int v=1;v<=i/2;v++) { int num=min(k,v*j); for(int u=0;u<=num;u++) { dp[i][j][k]=min(dp[i][j][k],dp[v][j][u]+dp[i-v][j][k-u]+j*j); } } for(int v=1;v<=j/2;v++) { int num=min(k,v*i); for(int u=0;u<=num;u++) { dp[i][j][k]=min(dp[i][j][k],dp[i][v][u]+dp[i][j-v][k-u]+i*i); } } } } } } int main() { int t; scanf("%d",&t); get_ans(); while(t--) { scanf("%d%d%d",&n,&m,&k); printf("%d\n",dp [m][k]); } return 0; }
相关文章推荐
- 0321《构建之法》现代软件工程第1、2、3章读后感
- PAT 乙级 1019. 数字黑洞
- 深入 PHP 面向对象、模式与实践
- C#学习笔记 线程同步问题
- 计算次数,POJ(1207)
- Android style用法
- 对称密钥与非对称密钥算法
- nginx conf文件结构介绍以及相关配置
- Unity5的AssetBundle的一点使用心得
- lintCode(114)——不同的路径
- 做程序员第二十天
- 整理一些C++面试容易被问到的问题及其答案
- WMI Attacks
- java第十四节-Collection接口-List
- 去除字符串中的空格
- 浏览器兼容性问题汇总及解决方案
- 前端工程师切图技能——PS工具准备
- ExtJs布局之border
- wc 统计程序
- 构建之法(前三章)读后感