题目链接

http://acm.timus.ru/problem.aspx?space=1&num=1005

题目大意

给你一堆石头,现在需要你将这堆石头分成两堆,要求两堆石头的重量相差最小,求这个最小的值是多少。

解题思路

看完题目之后,我们可以了解一下数据的规模,最多就20个石头,所以我们可以列出我们能够解题的一些方法:

  • 直接深度优先搜索,暴力得到每一种划分方法
  • 二进制枚举,这也是一种暴力求解方法
  • 将题目转化为01背包问题,动态规划求解

结合题目时间限制,我们最终选择第三种方法。所以现在来重点讲解下,这个题目需要怎么转化为01背包问题的。

首先,将石头划分成AB两堆,那么我们相当于从一堆石头里面挑选出若干个石头出来。对于每一块石头都有挑选或者不挑选两种选择。这就有点像01背包问题了,但是目前还不确定如何用01背包来求解。题目要求我们求解两堆石头的最小差,如果石头是可以掰开的,那么最理想的状态当然是两堆石头的重量都是原始那堆石头重量的一半avg,但是现实不是那么完美的,我们不能将石头掰开揉碎,而且很有可能最终的最好结果确实是一堆重一堆轻。

假设最优的结果是一堆石头重量为A,另外一堆是B,那么AB两者可能是其中一个大于等于avg,另外一个是小于等于avg。我们现在需要使|A-B|最小,那么最好是AB越靠近avg越好,这就相当于我们拿一个最大承重为avg的袋子去装石头,最多能装多少重量的石头。这就是一个01背包问题了。接下来我们只要求出这个背包问题的解,那么最后的差也就能够计算出来了。

解题代码

#include <cstdio>
#include <algorithm>
using namespace std; int n;
int wights[25];
int dp[25][100000*10+10]; int pack01(int volume) {
for (int i = 0; i <= volume; ++i) {
dp[0][i] = 0;
}
for (int i = 1; i <= n; ++i) {
for (int v = 0; v <= volume; ++v) {
if (v >= wights[i-1]) {
dp[i][v] = max(dp[i-1][v], dp[i-1][v-wights[i-1]]+wights[i-1]);
} else {
dp[i][v] = dp[i-1][v];
}
}
}
return dp[n][volume];
} int main() {
while (~scanf("%d", &n)) {
int tot = 0;
for (int i = 0; i < n; ++i) {
scanf("%d", &wights[i]);
tot += wights[i];
}
int ans = pack01(tot/2);
printf("%d\n", tot-2*ans);
}
return 0;
}

但是这种写法是有问题的,会超内存。所以我们应该用滚动数组来进行空间优化。

#include <cstdio>
#include <algorithm>
using namespace std; int n;
int wights[25];
int dp[100000*10+10]; int pack01(int volume) {
for (int i = 0; i <= volume; ++i) {
dp[i] = 0;
}
for (int i = 1; i <= n; ++i) {
for (int v = volume; v >= 0; --v) {
if (v >= wights[i-1]) {
dp[v] = max(dp[v], dp[v-wights[i-1]]+wights[i-1]);
}
}
}
return dp[volume];
} int main() {
while (~scanf("%d", &n)) {
int tot = 0;
for (int i = 0; i < n; ++i) {
scanf("%d", &wights[i]);
tot += wights[i];
}
int ans = pack01(tot/2);
printf("%d\n", tot-2*ans);
}
return 0;
}

我之所以解这个题目是因为,网易今年笔试出了一个这样的题目:

一种双核CPU的两个核能够同时处理任务,现在有n个一直数据量的任务需要交给CPU处理,假设已知CPU的每个核1秒可以处理1kb数据,每个核同时只能处理一项任务。n个任务可以按照任意顺序放入CPU进行处理,现在需要设计一个方案处理完这批任务所需要的时间最少,求这个最小的时间。

数据规模:

任务数最多为50个,每个任务的大小都是1024kb的整数倍,最大为4194304kb.

对于这样一种规模的数据,我们就绝对不能再暴力求解了。动态规划是一个很好的选择,但是在实际操作的过程中,我们需要注意空间的问题,因为每个任务都是1024kb的整数倍,所以我们可以将数据放缩到1到4096,这样再去解题才能通过。

Timus 1005 解题报告的更多相关文章

  1. POJ 1005 解题报告

    1.题目描述   2.解题思路 好吧,这是个水题,我的目的暂时是把poj第一页刷之,所以水题也写写吧,这个题简单数学常识而已,给定坐标(x,y),易知当圆心为(0,0)时,半圆面积为0.5*PI*(x ...

  2. hdu 1005解题报告

    这道题目n的取值范围很大,1 <= n <= 100,000,000.因此肯定是需要优化才能AC. 首先我考虑到时是有没有通项公式,研究了一下,没发现什么东西,突然看到两个1时就想到会不会 ...

  3. 【NOIP2015】提高day2解题报告

    题目: P1981跳石头 描述 一年一度的“跳石头”比赛又要开始了!这项比赛将在一条笔直的河道中进行,河道中分布着一些巨大岩石.组委会已经选择好了两块岩石作为比赛起点和终点.在起点和终点之间,有 N ...

  4. ZOJ_3950_How Many Nines 解题报告及如何对程序进行测试修改

    The 17th Zhejiang University Programming Contest Sponsored by TuSimple Solution: #include <stdio. ...

  5. POJ 2054 Color a Tree解题报告

    题干 Bob is very interested in the data structure of a tree. A tree is a directed graph in which a spe ...

  6. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  7. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  8. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  9. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

随机推荐

  1. GIT rebase讲解

    对分支进行rebase 从master分支checkout出fork分支,并在master和fork上都进行了一些修改 现在fork分支想要及时的同步master分支上的修改,避免在已经失效的代码上继 ...

  2. 用EXCEL批量更改文件名,一个命令就能完成

    工作任务:学籍库里需要更新和完善学生信息,其中有一项工作就是要导入以身份证号为文件名的学生照片,而目前各个班级提交的学生照片是以学生姓名命名的.如何将学生姓名批量转换成身份证号码呢? 解决方案:用EX ...

  3. Geatpy遗传算法在曲线寻优上的初步探究

    园子里关于遗传算法的教案不少,但基于geatpy框架的并未多见,故分享此文以作参考,还望广大园友多多指教! Geatpy出自三所名校联合团队之手,是遗传算法领域的权威框架(python),其效率之高. ...

  4. cp命令详解

    基础命令学习目录首页 http://man.linuxde.net/cp 如果把一个文件复制到一个目标文件中,而目标文件已经存在,那么,该目标文件的内容将被破坏.此命令中所有参数既可以是绝对路径名,也 ...

  5. 在Gulp中使用BrowserSync

    博客已迁移至http://zlwis.me. 很早就听说过BrowserSync,也看过一些相关文章,可就是没用过.之前一直在用Gulp开发项目,每次编写完Sass后还要用按F5刷新页面看效果,想想也 ...

  6. Scrum Meeting 10.26

    1.会议内容 姓名 今日任务 明日任务 预估时间(h) 徐越 学习服务器配置 配置SQLserver 4 卞忠昊 阅读代码 找上届代码的bug 3 武鑫 查阅资料 查阅资料,各种app的界面设计 3 ...

  7. 20172324 2017-2018-2《程序设计与数据结构》第五周 n!的计算

    20172324 2017-2018-2<程序设计与数据结构>实验2报告 课程:<程序设计与数据结构> 班级: 1723 姓名: 曾程 学号:20172324 实验教师:王志强 ...

  8. cnblogs.com用户体验

    一.是否提供了良好的体验给用户(同时提供价值)? 首先我觉得博客园给我们这些用户提供了良好的用户体验,博客园提供了一个纯净的技术交流空间,在这里我们可以找到几乎所有与IT技术有关的博文,而且可以在这里 ...

  9. HDU 4529 郑厂长系列故事——N骑士问题 状压dp

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4529 郑厂长系列故事--N骑士问题 Time Limit: 6000/3000 MS (Java/O ...

  10. 【转】(C#)OPC客户端源码

    本例下载/Files/badnewfish/OPC测试通过.rar 转载申明 申明:本文为转载,如需转载本文,请获取原文作者大尾巴狼啊的同意,谢谢合作! 转自:大尾巴狼啊 原文出处:http://ww ...