2015-09-21

              

               奶牛挤奶

  题目大意就是这只Bessie的牛产奶很勤奋,某农民有一个时刻表,在N时间内分成M个时间段,每个时间段Bessie会一直产奶,然后有一定的效益,并且Bessie产奶后要休息两个小时。

  这是一道很简答的DP,因为区间是不重复的,所以我们只要快排一下就好了,然后从第一个时间段到最后一个时间段

    状态转移方程:

      dp[i][j]=dp[i-1][j] j<i;

      dp[i][i]=MAX(dp[i][i],dp[i][j]+list[i].eff); j<i

    很简单是吧,我这道题做了两个小时????

    为什么???因为我快排写错了!

    代码一开始交的时候是1001*1001矩阵,时间是0ms,但是内存要用到7000+,用滚动数组时间到16ms,但是内存变成了132,还是值得的

  

 #include <stdio.h>
#include <stdlib.h>
#include <string.h>
#define MAX(a,b) (a)>(b)?(a):(b)
#define CUTOFF 20 typedef int Position;
typedef struct input
{
int start_hour;
int end_hour;
int eff;
}LIST; LIST list[];
long long dp1[];
long long dp2[]; void Quick_Sort(Position, Position);
void Swap(Position, Position);
void Insertion_Sort(Position, Position);
int Median_Of_Three(Position, Position, Position);
void Search(const int, const int, const int); int main(void)
{
int interval, R, N, i; while (~scanf("%d%d%d", &N, &interval, &R))
{
for (i = ; i <= interval; i++)
scanf("%d%d%d", &list[i].start_hour, &list[i].end_hour, &list[i].eff);
list[].start_hour = INT_MIN; list[].end_hour = -R;
Quick_Sort(, interval);
Search(N, interval, R);
}
return ;
} int Median_Of_Three(Position left, Position middle, Position right)
{
if (list[left].start_hour > list[middle].start_hour)
Swap(left, middle);
if (list[left].start_hour > list[right].start_hour)
Swap(left, right);
if (list[middle].start_hour > list[right].start_hour)
Swap(middle, right);
Swap(middle, right);//隐藏枢纽元
return list[right].start_hour;
} void Swap(Position x, Position y)
{
list[x].start_hour ^= list[y].start_hour;
list[y].start_hour ^= list[x].start_hour;
list[x].start_hour ^= list[y].start_hour; list[x].end_hour ^= list[y].end_hour;
list[y].end_hour ^= list[x].end_hour;
list[x].end_hour ^= list[y].end_hour; list[x].eff ^= list[y].eff;
list[y].eff ^= list[x].eff;
list[x].eff ^= list[y].eff;
} void Insertion_Sort(Position left, Position right)
{
Position i, j;
int tmp_s, tmp_e, tmp_eff;
for (i = left + ; i <= right; i++)
{
tmp_s = list[i].start_hour;
tmp_e = list[i].end_hour;
tmp_eff = list[i].eff;
for (j = i; j > left && list[j - ].start_hour > tmp_s; j--)
{
list[j].start_hour = list[j - ].start_hour;
list[j].end_hour = list[j - ].end_hour;
list[j].eff = list[j - ].eff;
}
list[j].start_hour = tmp_s;
list[j].end_hour = tmp_e;
list[j].eff = tmp_eff;
}
} void Quick_Sort(Position left, Position right)
{
Position mid = (left + right) / , i, j;
int pivot; if (right - left > CUTOFF)
{
pivot = Median_Of_Three(left, mid, right);
i = left; j = right;
while ()
{
while (list[++i].start_hour < pivot);
while (list[--j].start_hour > pivot);
if (i < j)
Swap(i, j);
else break;
}
Swap(i, right);
Quick_Sort(left, i - );
Quick_Sort(i + , right);
}
else Insertion_Sort(left, right);
} void Search(const int N, const int interval, const int R)
{
int i, j;
long long ans = -;
long long *now = dp2, *prev = dp1, *tmp = NULL; for (i = ; i <= interval; i++)
{
for (j = i - ; j >= ; j--)
{
now[j] = prev[j];
if (list[i].start_hour - list[j].end_hour >= R)
now[i] = MAX(now[i], now[j] + list[i].eff);
ans = MAX(ans, now[i]);
}
tmp = now; now = prev; prev = tmp;
}
printf("%lld\n", ans);
}

DP:Miking Time(POJ 3616)的更多相关文章

  1. POJ 3616 Milking Time (排序+dp)

    题目链接:http://poj.org/problem?id=3616 有头牛产奶n小时(n<=1000000),但必须在m个时间段内取奶,给定每个时间段的起始时间和结束时间以及取奶质量 且两次 ...

  2. poj 3616 Milking Time (基础dp)

    题目链接 http://poj.org/problem?id=3616 题意:在一个农场里,在长度为N个时间可以挤奶,但只能挤M次,且每挤一次就要休息t分钟: 接下来给m组数据表示挤奶的时间与奶量求最 ...

  3. POJ 3616 DP

    题意:给你N的时间,M的工作时间段,每个时间段有一个权重,还有一个R,每次完成一个工作需要休息R,问最后在时间N内,最大权重是多少. 思路:很简单的DP,首先对区间的右坐标进行排序,然后直接转移方程就 ...

  4. POJ 3616 Milking Time 简单DP

    题意:奶牛Bessie在0~N时间段产奶.农夫约翰有M个时间段可以挤奶,时间段f,t内Bessie能挤到的牛奶量e.奶牛产奶后需要休息R小时才能继续下一次产奶,求Bessie最大的挤奶量. 详见代码 ...

  5. POJ 3616 Milking Time (字符串DP)

    题意:找元素关于对角线左或右对称的最大矩阵 思路:左右对角线只需要遍历一条就可以了.只要当前点往上遍历和往后遍历一样就可以. #include<iostream> #include< ...

  6. poj 3616 Milking Time(dp)

    Description Bessie ≤ N ≤ ,,) hours (conveniently labeled ..N-) so that she produces as much milk as ...

  7. POJ 3616 Milking Time DP题解

    典型的给出区间任务和效益值,然后求最大效益值的任务取法. 属于一维DP了. 一维table记录的数据含义:到当前任务的截止时间前的最大效益值是多少. 注意. 这表示当前任务一定要选择,可是终于结果是不 ...

  8. POJ 3616 Milking Time 【DP】

    题意:奶牛Bessie在0~N时间段产奶.农夫约翰有M个时间段可以挤奶,时间段f,t内Bessie能挤到的牛奶量e.奶牛产奶后需要休息R小时才能继续下一次产奶,求Bessie最大的挤奶量.思路:一定是 ...

  9. poj 3616 奶牛产奶问题 dp算法

    题意:奶牛产奶,农夫有m个时间段可以挤奶,在工作时间 f t 内产奶量为m,每次挤完奶后,奶牛需要休息R.问:怎么安排使得产奶量最大? 思路:区间dp  dp[i]表示第i个时段 对农夫工作的结束时间 ...

随机推荐

  1. ACM算法总结及刷题参考

    参考:http://bbs.byr.cn/#!article/ACM_ICPC/11777 OJ上的一些水题(可用来练手和增加自信)(poj3299,poj2159,poj2739,poj1083,p ...

  2. 【ZOJ 3870】 Team Formation

    题意 n个数,找出有几对a.b 符合 a ^ b > max(a,b) .^表示异或号 分析 对于数a,如果它的二进制是: 1 0 1  0 0 1,那么和它 ^ 后 能比他大的数就是: 0 1 ...

  3. Yii2 radioList设置默认值

    可以在对应的Controller的action中设置 $model->type = 1; 在view中 <?php $form = ActiveForm::begin(); ?>   ...

  4. BZOJ-1207 打鼹鼠 DP(LIS)

    1207: [HNOI2004]打鼹鼠 Time Limit: 10 Sec Memory Limit: 162 MB Submit: 2276 Solved: 1116 [Submit][Statu ...

  5. Linux /proc、/dev Principle

    目录 . /proc简介 . 内核机制相关 . 进程信息 . 硬件设备相关 . 系统信息 . /dev简介 . 内存相关 1. /proc简介 在linux的根目录下有一个/proc目录,/proc文 ...

  6. 设置div居中

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  7. 使用Jquery+EasyUI 进行框架项目开发案例讲解之四 组织机构管理源码分享

    http://www.cnblogs.com/huyong/p/3404647.html 在上三篇文章  <使用Jquery+EasyUI进行框架项目开发案例讲解之一---员工管理源码分享> ...

  8. linux下的三种解压文件的命令?

    那要看你的压缩文件使用哪种压缩方式:gzip,压缩文件名:zip或gz,解压命令:unzipbzip2,压缩文件名:bz,解压命令:bzip2 -d上面两个是最常用的压缩方式,一般在linux下可以通 ...

  9. [LeetCode] next_permutation

    概念 全排列的生成算法有很多种,有递归遍例,也有循环移位法等等.C++/STL中定义的next_permutation和prev_permutation函数则是非常灵活且高效的一种方法,它被广泛的应用 ...

  10. 新浪微博客户端(24)-计算原创微博配图frame

    DJStatus.h #import <Foundation/Foundation.h> @class DJUser; /** 微博 */ @interface DJStatus : NS ...