【BZOJ1606】【Usaco2008 Dec】Hay For Sale

裸01背包

for(int i=;i<=n;i++)
for(int j=m;j>=a[i];j--)
f[j]=max(f[j],f[j-a[i]]+a[i]);

【BZOJ1607】【Usaco2008 Dec】轻拍牛头

暴力

【BZOJ1609】【Usaco2008 Feb】麻烦的聚餐

要求最长上升子序列或最长下降子序列的长度。

最基础的有dp算法

for(int i=;i<=n;i++)
for(int j=;j<=;j++){
for(int k=;k<=j;k++)f[i][j]=min(f[i-][k],f[i][j]);
if(a[i]!=j)f[i][j]++;
}

还有比较优的算法,nlogn求解最长上升子序列

这里的lower_bound找第一个大于x的数

bool cmp1(int a,int b){return a<=b;}
for(int i=;i<=n;i++) {
int k=lower_bound(g+,g++n,a[i],cmp1)-g;
g[k]=a[i];
ans=max(ans,k);
}

【BZOJ1613】【USACO2007 Jan】贝茜的晨练计划 DP

For(int i=;i<=n;i++){

  Dp[i][]=dp[i-][];

  For(int j=;j<=m;j++){

    Dp[i][]=max(dp[i][],dp[i-j][j]);

    Dp[i][j]=max(dp[i][j],dp[i-][j-]+a[i]);

  }

}

【BZOJ1622】【USACO2008 Open】名字的力量 暴力

N*M在字符串中找另一个字符串不需要连续

【BZOJ1623】【USACO2008 Open】奶牛飞车 贪心

因为速度要减去d(常数)*在前面的车数量,所以按速度从小到大,小的在前

【BZOJ1628】【USACO2007 Demo】City Skyline 堆

维护一个单调递增的栈,判断栈顶元素是否与a[i]相同

Ans=n;

For(int i=;i<=n;i++){

  if(q[top]>a[i]&&top>)top--;

  if(q[top]!=a[i])q[++top]=a[i];

  else ans--;
}

【BZOJ1633】【USACO2007 Feb】牛的词典 DP

Dp[i]表示I后最少要删的字母个数,dp[i]=min(dp[i+1]+1,f[i+len[j]+t]+t);

T为I后要删除t个字母才能找到s[j]

f[i]=f[i+]+;
for(int j=;j<=n;++j){
int now=,t=;
for(int k=i;k<m;++k) {
if(words[j][now]==s[k]) ++now;
else ++t;
if(now==words[j].length())break;
}
if(now==words[j].length()) f[i]=min(f[i],f[i+t+now]+t);
}

【BZOJ1634】【USACO2007 Jan】护花 贪心

对于每头牛来说都有自己ti*di代价

对于相邻两头牛,差异在于2*ta*db和2*tb*da,故写出比较函数,排序即可。

【BZOJ1635】【USACO2007 Jan】最高的牛

利用前缀和的思想,对于x,y,sum[x+1]++;sum[y]--;

求前缀和,用最高的height减去。

【BZOJ1636】【USACO2007 Jan】Balanced Lineup

ST表

【BZOJ1637】【USACO2007 Mar】Balanced Lineup sort一下乱搞搞

对于0种族 -1,对于1种族+1,求前缀和,对于每一种前缀和标记最早出现的位置

1~n循环一下,取最大值。

【BZOJ1638】【USACO2007 Mar】奶牛交通 DAG上DP

正向dp到一个点的路径条数,反向dp一遍,对于每条边经过次数即前端点*后端点,取max

【BZOJ1639】【USACO2007 Mar】月度开支

二分贪心

【BZOJ1640】【USACO2007 Nov】队列变换 贪心

如果前后相等就继续比较较内的字符

【BZOJ1641】【USACO2007 Nov】奶牛跨栏 用类似Prim的方法预处理即可

Floyd

 for(int k=;k<=n;k++)
for(int i=;i<=n;i++)
for(int j=;j<=n;j++)
f[i][j]=min(f[i][j],max(f[i][k],f[k][j]));

【BZOJ1642】【USACO2007 Nov】挤奶时间 DP

读入后,按照左端点排序,右端点直接加上等待时间。

F[I]表示第I个任务及以前的最大产奶量

f[i]=max(f[1]…f[i-1])+v[i]; (r[j]<=l[i])

【BZOJ1646】【USACO2007 Open】抓住那头牛 BFS

可以向前走,向后走,*2.

【BZOJ1648】【USACO2006 Dec】奶牛野餐

暴力DFS

【BZOJ1649】【USACO2006 Dec】Cow Roller Coaster DP

按照左端点排序,左端点相同排右端点

F[i][j]表示到I长度,成本为j

F[i][j]=max(f[i][j],f[a[i].l][j-a[i].c]+a[i[.f

【BZOJ1650】【USACO2006 Dec】跳石子

二分贪心

【BZOJ1651】【USACO2006 Feb】专用牛棚 堆贪心

a[l]+1,a[r+1]-1,求前缀和,取最大值

【BZOJ1688】【USACO2005 Open】疾病管理 状压DP

不知道为什么暴力时间复杂度不对,但就是过了

不过顺便学习了bitset(测试后发现时间上并没有比bool快多少(可能因为数据水

zyf-zyf:但是好写呀!

#include<bitset>
bitset<NUM> b;

bitset<NUM> b(int/string);

b.reset();清0

b.set();赋1

b.set/reset(pos);

b.count();1的个数

b.flip(pos/ /);取反

正解状态压缩dp~额,其实时间复杂度基本一样

用二进制表示每一头牛的得病情况

f[j|a[i]]=max(f[j|a[i]],f[j]+1)

【BZOJ1689】【USACO2005
Open】泥泞的路 贪心

按照左端点排序,尽量覆盖,贪心。

usaco silver刷水~其实是回顾一下,补题解的更多相关文章

  1. Luogu USACO Training 刷水记录

    开个坑记录一下刷USACO的Training的记录 可能会随时弃坑 只有代码和做法简述 可能没有做法简述 [USACO1.1]你的飞碟在这儿Your Ride Is He… 模拟,细节已忘 #incl ...

  2. [洛谷U22157]刷水题(数位dp)(hash)

    题目背景 做正经题是不可能做正经题的,这辈子都不可能做正经题的,毒瘤题又不会做毒瘤题,就是水题这种东西,才维持了蒟蒻的信心: 题目描述 这里有N+1 道水题,编号分别为0 ~N+1 ,每道水题都有它自 ...

  3. USACO 刷水

    BZOJ 1666 水.. BZOJ 1579 分层图最短路. BZOJ 1782 从一开始若某头牛停在U,那么U的子树的时间都会加一用BIT维护DFS序就行了 BZOJ 1572 贪心+堆 排序后查 ...

  4. bzoj刷水

    因为最近的生活太颓废总是不做题而被老师D了一番, 所以今天晚上到bzoj上去刷了几道水题.....   bzoj 4320: ShangHai2006 Homework 题目大意 维护一个支持两个操作 ...

  5. usaco silver

    大神们都在刷usaco,我也来水一水 1606: [Usaco2008 Dec]Hay For Sale 购买干草   裸背包 1607: [Usaco2008 Dec]Patting Heads 轻 ...

  6. BZOJ USACO 银组 水题集锦

    最近刷银组刷得好欢快,好像都是水题,在这里吧他们都记录一下吧(都是水题大家一定是道道都虐的把= =)几道比较神奇的题到时再列出来单独讲一下吧= =(其实我会说是BZOJ蹦了无聊再来写的么 = =) [ ...

  7. [暑假的bzoj刷水记录]

    (这篇我就不信有网站来扣) 这个暑假打算刷刷题啥的 但是写博客好累啊  堆一起算了 隔一段更新一下.  7月27号之前刷的的就不写了 , 写的累 代码不贴了,可以找我要啊.. 2017.8.27upd ...

  8. 【刷水】之USACO2008资格赛(Bzoj1599-1603)

    做之前真是没想到有这么水>.< 但做了还是发上来吧>.< 就当是刷一刷AC量&1A率什么的>.< Bzoj1599: [Usaco2008 Oct]笨重的石 ...

  9. Codeforces 刷水记录

    Codeforces-566F 题目大意:给出一个有序数列a,这个数列中每两个数,如果满足一个数能整除另一个数,则这两个数中间是有一条边的,现在有这样的图,求最大联通子图. 题解:并不需要把图搞出来, ...

随机推荐

  1. 【翻译六】java-连接和实例

    Joins The join method allows one thread to wait for the completion of another. If t is a Thread obje ...

  2. SQLAlchemy Core中的异常及事务处理样码

    这部门内容比较简单,立存. #coding=utf-8 from datetime import datetime from sqlalchemy import (MetaData, Table, C ...

  3. 手机WebAPP设计注意事项和解决方法

    1. 基本手机网页设计 1.1 wap端的网站表头 wap端的网站,写的时候首先注意表头,因为是手机端的,所以和我们平常用的web端页面的不一样,表头为: 1.2 尽量少使用水平滚动. 水平滚动除了比 ...

  4. 数据库是.frm,.myd,myi备份如何导入mysql (转)

    今天找了个案例,琢磨了半天,才分析大概出来,数据库是.frm,.myd,myi备份,不会导入mysql,到网上找了些资料,导入成功. 首先说一下这几种文件是干什么的,*.frm是描述了表的结构,*.M ...

  5. 德飞莱STM32单片机学习(一)——下载环境搭建

    一.下载驱动安装. 1.手动打开CH341 文件夹(驱动程序文件夹内) ,双击安装驱动 2. 尼莫M3S 开发硬件设置 硬件需要做到以下2 点:1. USB插入USB1(COM),打开电源开关J14( ...

  6. 使用jQuery要注意的问题

    1. $.find()与$.children()的区别 有如下HTML片段: 复制代码代码如下: <div id="div_four"> <input id=&q ...

  7. CodeForces 710F 强制在线AC自动机

    题目链接:http://codeforces.com/contest/710/problem/F 题意:维护一个集合,集合要求满足三种操作. 1 str:向集合插入字符串str(保证不会插入之前已经插 ...

  8. POJ 3261 后缀数组

    题目链接:http://poj.org/problem?id=3261 题意:约翰注意到奶牛产奶的之类是不断变化的,虽然他不能预测从当天到下一天的变化情况但是他知道变化是有规律的,牛奶的质量由一个整数 ...

  9. redis 存储session实现session共享

    nginx 作为代理 tomcat集群 redis存储共享session nginx采用轮询方式将动态请求反向代理给tomcat,tomcat通过加载相应jar包方式实现获得redis中共享的sess ...

  10. Postman - HTTP接口测试工具

    Postman 是一个 Chrome 的 插件,它主要是用来模拟各种HTTP请求的(如:get/post/delete/put..等等),下面介绍下Postman的安装和使用方法: 一.安装Postm ...