bzoj3380+3381+3382+3383 Usaco2004 Open
四道比较水的题
T1:SPFA+状压
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<queue>
#define INF 0x3f3f3f3f
using namespace std;
],dis[][],num,N,f[<<][],ans,vis[],mp[][];
void get_dis(int num){
queue<,sizeof(vis));
Q.push(num); dis[num][num]=INF; vis[num]=;
while (!Q.empty()){
int now=Q.front(); Q.pop();
; i<=n; i++){
){
dis[num][i]=max(dis[num][i],min(dis[num][now],mp[now][i]));
;
}
}
}
}
int main(){
scanf("%d%d%d", &n, &m, &K);
; i<=K; i++) scanf("%d", &id[i]);
memset(dis,,sizeof(dis));
,u,v,w; i<=m; i++) scanf("%d%d%d", &u, &v, &w),mp[v][u]=mp[u][v]=w;
; i<=n; i++) get_dis(i);
N=(<<K);
; i<=K; i++) f[<<(i-)][i]=;
; s<N; s++){
num=;
; i<=K; i++) <<(i-))) num++;
; i<=K; i++) <<(i-))){
; j<=K; j++) <<(j-))))
<<(j-))][j]|=f[s][i];
}
; i<=K; i++) <<(i-))) && f[s][i]){
]);
ans=max(ans,t);
}
}
printf("%d\n", ans);
;
}
T2:裸RMQ
#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<cmath>
using namespace std;
;
];
int main(){
scanf("%d%d", &n, &m);
; i<=n; i++) scanf(]);
; (<<j)<=n; j++)
; i+(<<(j-))<=n; i++)
f[i][j]=min(f[i][j-],f[i+(<<(j-))][j-]);
,a,b; i<=m; i++){
scanf("%d%d", &a, &b);
)/log();
printf(<<t)+][t]));
}
;
}
T3:曼哈顿距离转切比雪夫距离
#include<stdio.h>
#include<algorithm>
#include<string.h>
#define INF 1000010
using namespace std;
int n,a,b,x,y,mxx,mxy,mnx,mny;
int main(){
scanf("%d", &n);
mxx=mxy=-INF; mnx=mny=INF;
; i<=n; i++){
scanf("%d%d", &a, &b);
x=b+a; y=b-a;
mnx=min(mnx,x); mxx=max(mxx,x);
mny=min(mny,y); mxy=max(mxy,y);
}
printf("%d\n", max(mxx-mnx,mxy-mny));
;
}
T4:set+最短路
#include<stdio.h>
#include<string.h>
#include<queue>
#include<set>
#include<algorithm>
using namespace std;
;
struct node{
int x,y,id;
friend bool operator<(node a, node b){
if (a.x==b.x) return a.y<b.y;
return a.x<b.x;
}
};
int n,t,x[maxn],y[maxn],dis[maxn];
queue<int> Q;
set<node> st;
node mk(int x, int y, int id){
node a; a.x=x; a.y=y; a.id=id; return a;
}
int main(){
scanf("%d%d", &n, &t);
; i<=n; i++){
scanf("%d%d", &x[i], &y[i]);
st.insert(mk(x[i],y[i],i));
}
dis[]=; x[]=y[]=;
Q.push();
while (!Q.empty()){
int now=Q.front(); Q.pop();
; i<=; i++) ; j<=; j++){
int X=x[now]+i, Y=y[now]+j;
));
if (next!=st.end()){
dis[next->id]=dis[now]+;
Q.push(next->id);
if (Y>=t){
printf("%d\n", dis[next->id]);
;
}
st.erase(next);
}
}
}
puts("-1");
;
}
bzoj3380+3381+3382+3383 Usaco2004 Open的更多相关文章
- Hsql中In没有1000的限制
SELECT * FROM user , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , , ...
- 基于json的jquery地区联动探索
贴一个基于jquery联动的代码,相信这样的代码有一大把,就当是jquery的练手吧, 写这个东西的初衷是来之于新浪微博,在新浪微博帐号设置里面有个地区的选项,使用js写的,想把它的代码给截获下来,可 ...
- JS逆向-抠代码的第二天【手把手学会抠代码】
今天的学习项目:沃支付:https://epay.10010.com/auth/login 清空浏览器缓存后,打开网页,输入手机号,密码222222,按照网站要求填入验证码(sorry,我没有账号密码 ...
- 游戏中的自动寻路-A*算法(第一版优化——走斜线篇)
一.简述以及地图 G 表示从起点移动到网格上指定方格的移动距离 (暂时不考虑沿斜向移动,只考虑上下左右移动). H 表示从指定的方格移动到终点的预计移动距离,只计算直线距离,走直角篇走的是直角路线. ...
- bzoj AC倒序
Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...
- jqu
1 /*2 * 说明:3 * 本源代码的中文注释乃Auscarlin呕心沥血所作.旨在促进jQuery的传播以及向广大jQuery爱好者提供一个进阶4 *的途径,以让各位更加深入地了解jQuery,学 ...
- 3381: [Usaco2004 Open]Cave Cows 2 洞穴里的牛之二
3381: [Usaco2004 Open]Cave Cows 2 洞穴里的牛之二 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 21 Solved ...
- bzoj3380: [Usaco2004 Open]Cave Cows 1 洞穴里的牛之一(spfa+状压DP)
数据最多14个有宝藏的地方,所以可以想到用状压dp 可以先预处理出每个i到j的路径中最小权值的最大值dis[i][j] 本来想用Floyd写,无奈太弱调不出来..后来改用spfa 然后进行dp,这基本 ...
- [BZOJ3380] [USACO2004 Open]Cave Cows 1 洞穴里的牛之一
Description 很少人知道其实奶牛非常喜欢到洞穴里面去探险. 洞窟里有N(1≤N≤100)个洞室,由M(1≤M≤1000)条双向通道连接着它们.每对洞室间 至多只有一条双向通道.有K( ...
随机推荐
- Position属性四个值:static、fixed、absolute和relative的区别和用法
Position属性四个值:static.fixed.absolute和relative的区别和用法 在用CSS+DIV进行布局的时候,一直对position的四个属性值relative,absolu ...
- MongoVue中Collections无法显示的问题
问题描述: 通过Python向MongoDB写入数据后,MongoVue中Collections无法显示的问题 原因: Mongodb 3.0之后默认的 storageEngine为wiredTige ...
- vim 加行号 和取消行号
:set nu #是加行号 :set nonu #是去掉行号
- .NET Attribute 入门【笔记】
闲谈:没有系统的学过,偶尔看看,看的也不是很清楚. 却一直不明白,本来也不难,自己动手写了个示例.结果一目了然…… Attribute —— 标记 可以对方法.类等事务进行附着.增加属性. 下面以我见 ...
- 关于安装CentOS 7 的注意事项
1.安装VMware Workstation 2.安装CentOS的时候选择GNOME桌面 3.联网设置, VMWare Network Apapter VMnet8 设置IP4 自动获取IP地址,“ ...
- 【Java EE 学习 79 上】【mybatis 基本使用方法】
一.简介 mybatis类似于hibernate,都是简化对数据库操作的框架,但是和hibernate不同的是,mybatis更加灵活,整体来说框架更小,这体现在它需要我们手写SQL语句,而hiber ...
- Spring MVC注解入门
注解式开发初步 常用的两个注解: @Controller:是SpringMVC中最常用的注解,它可以帮助定义当前类为一个Spring管理的bean,同时指定该类是一个控制器,可以用来接受请求.标识当前 ...
- 【Hibernate框架】关联映射(多对多关联映射)
按着我们的总结行进计划,接下来,就是有关于多对多映射的总结了. 我们来举个例子啊,很长时间以来,房价暴涨不落,但是还有很多人拥有很多套房产,假如说,一个富豪拥有九套房产,家里人么准去住哪一套,我们就以 ...
- 常见css垂直自适应布局(css解决方法)
css3的盒模型, css3中添加弹性盒模型,最新弹性盒模型是flex,之前为box <!DOCTYPE html> <html > <head> <titl ...
- [spring源码学习]单元测试演化
1.使用main方法 最早的测试方法一般是在类中增加main方法,然后在main方法中增加对每个方法的测试代码,如果要测其中一个,就屏蔽掉其他的测试代码,执行后,根据log的打印来判断测试是否成功 2 ...