BJOI2015 Day2
轮到罗剑桥出题了

这是什么风格,中文名称与英文名称分明对不上吗233
T1:


似乎只会做这道题23333
A....BE
........
C....DF
据题意数学变形得A-C<=B-D,B-D<=E-F,即左右的差是递增的。
A....B
.......
C....D
E....F
据题意数学变形得A-B<=C-D,C-D<=E-F,即上下的差是递增的。
那么令f1[i][j]=A[i][j]-A[i+1][j],f2[i][j]=A[i][j]-A[i][j+1]。
只有当f1[i][j-1]<=f1[i][j]且f2[i-1][j]<=f2[i][j]时 (i,j)才能进入矩形中。
那么问题就转化成最大子矩形,其内部没有坏点。
#include<cstdio>
#include<cctype>
#include<cstring>
#include<algorithm>
#define rep(i,s,t) for(int i=s;i<=t;i++)
using namespace std;
inline int read() {
int x=,f=;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-;
for(;isdigit(c);c=getchar()) x=x*+c-'';
return x*f;
}
const int maxn=;
int A[maxn][maxn],B[maxn][maxn],C[maxn][maxn],n,m,ans;
int is[maxn][maxn];
int right[maxn],left[maxn],up[maxn][maxn];
int main() {
freopen("neo.in","r",stdin);
freopen("neo.out","w",stdout);
n=read();m=read();
rep(i,,n) rep(j,,m) A[i][j]=read();
rep(i,,n) rep(j,,m) B[i][j]=A[i][j]-A[i+][j],C[i][j]=A[i][j]-A[i][j+];
n--;m--;
rep(i,,n) rep(j,,m) if(B[i][j]<=B[i][j+]&&C[i][j]<=C[i+][j]) is[i][j]=;
rep(i,,n) {
rep(j,,m) {
if(!is[i][j]) continue;
up[i][j]=up[i-][j]+;
if(j==) left[j]=;
else {
left[j]=j;
while(up[i][left[j]-]>=up[i][j]) left[j]=left[left[j]-];
}
}
for(int j=m;j;j--) {
if(!is[i][j]) continue;
if(j==m) right[j]=m;
else {
right[j]=j;
while(up[i][right[j]+]>=up[i][j]) right[j]=right[right[j]+];
}
ans=max(ans,(up[i][j]+)*(right[j]-left[j]+));
}
}
printf("%d\n",ans);
return ;
}
T2:简要题意,计算从最上角上方连一条管道到最下角下方的方案书数。
显然是不可做的插头DP,写个暴搜60
#include<cstdio>
#include<cctype>
#include<cstring>
#include<algorithm>
#define rep(i,s,t) for(int i=s;i<=t;i++)
using namespace std;
inline int read() {
int x=,f=;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-;
for(;isdigit(c);c=getchar()) x=x*+c-'';
return x*f;
}
const int maxn=;
int n,m,ans;
char A[maxn][maxn];
int have[maxn][maxn];
int mx[]={,-,,},my[]={,,,-};
void dfs(int x,int y) {
have[x][y]=;
if(x==n&&y==m) ans++;
else rep(dir,,) if(x>=&&x<=n&&y>=&&y<=m&&!have[x+mx[dir]][y+my[dir]]&&A[x+mx[dir]][y+my[dir]]=='.') dfs(x+mx[dir],y+my[dir]);
have[x][y]=;
}
int main() {
freopen("voda.in","r",stdin);
freopen("voda.out","w",stdout);
n=read();m=read();
rep(i,,n) scanf("%s",A[i]+);
if(A[][]=='#'||A[n][m]=='#') {puts("");return ;}
dfs(,);printf("%d\n",ans%);
return ;
}
T3:有一个N层M格的书架,可以将一本书移动到另一层,也可以把同一层的书左右移动,求从初始状态到最终状态的最少移动数。
考虑那些前后所在层不变的书,应对答案贡献总数-LCS的数目,如果这层全满,需要答案额外+1(先将一本拿到别层再拿回来)。
对于前后所在层变化的书,答案要+1表示移动一次,如果所在连通分量全满,同理答案要再+1.
#include<cstdio>
#include<cctype>
#include<cstring>
#include<algorithm>
#define rep(i,s,t) for(int i=s;i<=t;i++)
using namespace std;
inline int read() {
int x=,f=;char c=getchar();
for(;!isdigit(c);c=getchar()) if(c=='-') f=-;
for(;isdigit(c);c=getchar()) x=x*+c-'';
return x*f;
}
const int maxn=;
int m,C[maxn],t[maxn*maxn],g[maxn];
int get(int* C,int len) {
int ans=;
rep(i,,len) g[i]=<<;
rep(i,,len) {
int k=lower_bound(g+,g+len+,C[i])-g;
ans=max(ans,k);g[k]=C[i];
}
return ans;
}
int n,A[maxn][maxn],B[maxn][maxn],yes[maxn],ans;
int pos[maxn*maxn],pos2[maxn*maxn],first[maxn],next[maxn*maxn*],to[maxn*maxn*],e;
void AddEdge(int u,int v) {
ans++;
to[++e]=v;next[e]=first[u];first[u]=e;
to[++e]=u;next[e]=first[v];first[v]=e;
}
int vis[maxn],f[maxn];
int dfs(int x) {
if(vis[x]) return f[x];vis[x]=;
int& ans=f[x];ans=!yes[x];
for(int i=first[x];i;i=next[i]) ans&=dfs(to[i]);
return ans;
}
int main() {
freopen("police20.in","r",stdin);
freopen("police.out","w",stdout);
n=read();m=read();int ok=,dif=;
rep(i,,n) rep(j,,m) {
A[i][j]=read();
if(!A[i][j]) ok=yes[i]=;
else pos[A[i][j]]=i,pos2[A[i][j]]=j;
}
rep(i,,n) rep(j,,m) {
B[i][j]=read();
if(B[i][j]&&i!=pos[B[i][j]]) AddEdge(i,pos[B[i][j]]);
}
rep(i,,n) {
int len=;
rep(j,,m) if(B[i][j]&&pos[B[i][j]]==i) C[++len]=pos2[B[i][j]];
int tmp=len-get(C,len);
if(tmp) ans+=tmp+(len==m);
}
if(ans&&!ok) puts("-1");
else {
rep(i,,n) if(!vis[i]&&first[i]) ans+=dfs(i);
printf("%d\n",ans);
}
return ;
}
BJOI2015 Day2的更多相关文章
- 【从零开始学BPM,Day2】默认表单开发
[课程主题]主题:5天,一起从零开始学习BPM[课程形式]1.为期5天的短任务学习2.每天观看一个视频,视频学习时间自由安排. [第二天课程] Step 1 软件下载:H3 BPM10.0全开放免费下 ...
- NOIp2016 Day1&Day2 解题报告
Day1 T1 toy 本题考查你会不会编程. //toy //by Cydiater //2016.11.19 #include <iostream> #include <cstd ...
- day2
三级菜单: ))))))))))] last_levels.pop() ]]]]]]]]:] information = : ch = msvcrt.getch() ][][: : password= ...
- java day2一个模拟双色球的代码
package day2; import java.awt.Color; import java.awt.Font; import java.awt.Graphics; import java.awt ...
- Python基础-day2
1.Python模块python 中导入模块使用import语法格式:import module_name示例1: 导入os模块system('dir')列出当前目录下的所有文件 # _*_ codi ...
- 【BZOJ 4517】【SDOI 2016 Round1 Day2 T2】排列计数
本蒟蒻第一次没看题解A的题竟然是省选$Round1$ $Day2$ $T2$ 这道组合数学题. 考试时一开始以为是莫队,后来想到自己不会组合数的一些公式,便弃疗了去做第三题,,, 做完第三题后再回来看 ...
- 冲刺阶段 day2
day2 项目进展 今天本组五位同学聚在一起将项目启动,首先我们对项目进行了规划,分工,明确指出每个人负责哪些项目.由负责第一部分的组员开始编程,在已经搭建好的窗体内,对系部设置进行了编写,本校共六个 ...
- BZOJ 4337: BJOI2015 树的同构 树hash
4337: BJOI2015 树的同构 题目连接: http://www.lydsy.com/JudgeOnline/problem.php?id=4337 Description 树是一种很常见的数 ...
- python_way ,day2 字符串,列表,字典,时间模块
python_way ,day2 字符串,列表,字典,自学时间模块 1.input: 2.0 3.0 区别 2.0中 如果要要用户交互输入字符串: name=raw_input() 如果 name=i ...
随机推荐
- Cannot locate factory for objects of type DefaultGradleConnector, as ConnectorServiceRegistry has been closed.
现象:更换android studio libs文件夹下的jar包,重新编译代码报错:Cannot locate factory for objects of type DefaultGradleCo ...
- 1.7 逆序数与归并排序[inversion pairs by merge sort]
[本文链接] http://www.cnblogs.com/hellogiser/p/inversion-pairs-by-merge-sort.html [题目] 编程之美1.7光影切割问题可以进一 ...
- 31.从尾到头输出链表[Print linked list from last to first]
[题目] 输入一个链表的头结点,从尾到头反过来输出每个结点的值. [分析] 这是一道很有意思的面试题.该题以及它的变体经常出现在各大公司的面试.笔试题中. [链表逆置] 看到这道题后,第一反应是从头到 ...
- Cocos2d 初学基本知识
1. 纹理(Texture) 游戏角色的图像文件在使用前必须解压缩,并转换成 iPhone 和 iPad 的 GPU 可以理解的 格式,同时要加载进 RAM(随机存储器),这样的图像称为纹理.GPU ...
- Android 中PendingIntent---附带解决AlarmManager重复加入问题
最近在程序中使用到了notification功能,自然,就涉及到了PendingIntent,下面总结下. 1 什么是PendingIntent A description of an Intent ...
- Linux的文件管理
绝对路径和相对路径: 绝对路径: /home/tony/Desktop 相对路径:Desktop 或者./Desktop不可写成/Desktop(这是绝对路径的写法) 其中.代表本层目录,..代表上层 ...
- 【USACO】numtri
给一颗数字树,让找一条数字和最大的路径.一下子就想起刚学不久的回溯法了.照着写了个代码,调了调搞通了.在小数据的情况下是对的,但是在test 6 树有199层的时候溢出了. #include < ...
- osg 中鼠标拾取线段的端点和中点
//NeartestPointNodeVisitor.h #pragma once #include <osg\Matrix> #include <vector> #inclu ...
- Auguse 2nd, Week 32nd Tuesday, 2016
Love me little and love me long.不求情意绵绵,但愿天长地久. Friends are relatives you make for yourself.朋友是你自己结交的 ...
- Java并发编程:Synchronized及其实现原理
Java并发编程系列: Java 并发编程:核心理论 Java并发编程:Synchronized及其实现原理 Java并发编程:Synchronized底层优化(轻量级锁.偏向锁) Java 并发编程 ...