分析

这道题看上去很恶心,实际上只用记录四坨东西就能打DP了:y坐标最小的向上射的点、y坐标最大的向下射的点、y坐标最大和最小的向右射的点,转移显然。注意,如果该状态的值为零就可以略过,否则会超时。

#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <algorithm>
#include <cstring>
using namespace std;
int a[60][3],f[2][57][57][57][57],xz[55],xy[55],ys[55],yx[55];
int n,m,tot;
void q(int l,int r)
{
int i=l,j=r,mid=a[(l+r)/2][1],e;
while(i<j)
{
while(a[i][1]<mid) i++;
while(a[j][1]>mid) j--;
if(i<=j)
{
e=a[i][1];
a[i][1]=a[j][1];
a[j][1]=e;
e=a[i][2];
a[i][2]=a[j][2];
a[j][2]=e;
i++;
j--;
}
}
if(i<r) q(i,r);
if(l<j) q(l,j);
}
void q1(int l,int r)
{
int i=l,j=r,mid=a[(l+r)/2][2],e;
while(i<j)
{
while(a[i][2]<mid) i++;
while(a[j][2]>mid) j--;
if(i<=j)
{
e=a[i][1];
a[i][1]=a[j][1];
a[j][1]=e;
e=a[i][2];
a[i][2]=a[j][2];
a[j][2]=e;
i++;
j--;
}
}
if(i<r) q1(i,r);
if(l<j) q1(l,j);
}
int main()
{
cin>>n;
int i,j,k,l,p,x,y;
for(i=1;i<=n;i++)
{
cin>>a[i][1]>>a[i][2];
xz[i]=xy[i]=ys[i]=yx[i]=56;
}
xz[0]=xy[0]=ys[0]=yx[0]=56;
q1(1,n);
tot=0;
p=-2000000000;
for(i=1;i<=n;i++)
{
if(a[i][2]==p)
{
a[i][2]=tot;
}
else
{
p=a[i][2];
a[i][2]=++tot;
}
}
q(1,n);
tot=0;
p=-2000000000;
for(i=1;i<=n;i++)
{
if(a[i][1]==p)
{
a[i][1]=tot;
}
else
{
p=a[i][1];
a[i][1]=++tot;
}
if(xz[a[i][2]]==56)
xz[a[i][2]]=a[i][1];
else
xz[a[i][2]]=min(xz[a[i][2]],a[i][1]); if(xy[a[i][2]]==56)
xy[a[i][2]]=a[i][1];
else
xy[a[i][2]]=max(xy[a[i][2]],a[i][1]); if(yx[a[i][1]]==56)
yx[a[i][1]]=a[i][2];
else
yx[a[i][1]]=min(yx[a[i][1]],a[i][2]); if(ys[a[i][1]]==56)
ys[a[i][1]]=a[i][2];
else
ys[a[i][1]]=max(ys[a[i][1]],a[i][2]);
}
int mo=998244353;
f[0][n+1][0][0][n+1]=1;
int ans=0;
for(i=0;i<=n;i++)
{
memset(f[(i+1)%2],0,sizeof(f[(i+1)%2]));
for(int up=0;up<=n+1;up++)
for(int down=0;down<=n+1;down++)
for(int mx=0;mx<=n+1;mx++)
for(int mn=0;mn<=n+1;mn++)
if(f[i%2][up][down][mx][mn])
{
int sum=0;
int t=f[i%2][up][down][mx][mn];
//上
if(a[i+1][2]==ys[a[i+1][1]] && mx<a[i+1][2])
(f[(i+1)%2][min(up,a[i+1][2])][down][mx][mn]+=t)%=mo,(sum+=t)%=mo;
//下
if(a[i+1][2]==yx[a[i+1][1]] && mn>a[i+1][2])
(f[(i+1)%2][up][max(down,a[i+1][2])][mx][mn]+=t)%=mo,(sum+=t)%=mo;
//左
if(a[i+1][1]==xz[a[i+1][2]] && up>a[i+1][2] && down<a[i+1][2])
(f[(i+1)%2][up][down][mx][mn]+=t)%=mo,(sum+=t)%=mo;
//右
if(a[i+1][1]==xy[a[i+1][2]])
(f[(i+1)%2][up][down][max(mx,a[i+1][2])][min(mn,a[i+1][2])]+=t)%=mo,(sum+=t)%=mo;
if(i==n-1) ans=(ans+sum)%mo;
}
}
cout<<ans;
}

【C】题解 (五校联考3day2)的更多相关文章

  1. 【五校联考3day2】C

    題意: 現有一平面直角坐標系,有n個點,每一個點必須向某一個方向發射射線,且任意一條射線必須與某一條坐標軸平行.定義一種發射射線的方案是合法的,則方案必須滿足: 1.沒有一條射線交叉 2.沒有一條射線 ...

  2. 【五校联考1day2】JZOJ2020年8月12日提高组T2 我想大声告诉你

    [五校联考1day2]JZOJ2020年8月12日提高组T2 我想大声告诉你 题目 Description 因为小Y 是知名的白富美,所以自然也有很多的追求者,这一天这些追求者打算进行一次游戏来踢出一 ...

  3. 【五校联考1day2】JZOJ2020年8月12日提高组T1 对你的爱深不见底

    [五校联考1day2]JZOJ2020年8月12日提高组T1 对你的爱深不见底 题目 Description 出乎意料的是,幸运E 的小R 居然赢了那个游戏.现在欣喜万分的小R 想要写一张明信片给小Y ...

  4. 【宝藏】题解(五校联考3day1)

    分析 如果打爆搜的话可以拿60分. 首先知道期望是可以累加的,即i通过j去到k的期望,等于i去到j的期望加j去到k的期望. 所以令d[i]表示i的出度,F[i]表示从i到i的父亲的期望,G[i]表示i ...

  5. NOIP2016提高A组五校联考3总结

    第一题,本来一开始就想到了数位dp,结果脑残地打了十几个转移方程,总是调试不出来,一气之下放弃了. 调第一题几乎调了整节比赛,第二第三都没它. 第二题连边找联通块. 第三题题解都打了三页,看都不想看. ...

  6. 【五校联考5day1】登山

    题目 描述 题目大意 给你一个n∗nn*nn∗n的网格图.从(0,0)(0,0)(0,0)开始,每次只可以向右或向上移动一格,并且不能越过对角线(即不能为x<yx<yx<y). 网格 ...

  7. 【2020五校联考NOIP #2】矩阵

    咕咕咕到现在~ 题面传送门 题意: 给出一个 \(n\times n\) 的矩阵 \(A\).要你求有多少个 \(n\times n\) 的矩阵 \(B\) 满足: 每一行都是 \(1\) 到 \(n ...

  8. 五校联考 running (欧拉函数)

    题面 \(solution:\) 讲真吧,这道题真的出得,嗯,太恐怖了.考场上这道题真的把我看懵了,这道题以前是见过的,但欧拉函数?我学过吗?一道容斥都要超时的题目,我都要为我自己点根香了,拿着gcd ...

  9. 五校联考R1 Day1T3 平面图planar(递推 矩阵快速幂)

    题目链接 我们可以把棱柱拆成有\(n\)条高的矩形,尝试递推. 在计算的过程中,第\(i\)列(\(i\neq n\))只与\(i-1\)列有关,称\(i-1\)列的上面/下面为左上/左下,第\(i\ ...

随机推荐

  1. VS Code 使用Git进行版本控制

    在Windows上安装Git:msysgit是Windows版的Git,从https://git-for-windows.github.io下载 Git安装到环境变量里,确保任意路径可以访问:将git ...

  2. es为什么要取消type? 或者为什么一个index下多个type会有问题

    同一个index下的不同的type下的相同的filed,在同一个index下其实会被认为是同一个filed. 否则,不同type中的相同字段名称就会在处理中出现冲突的情况,导致Lucene处理效率下降

  3. MACBOOK蓝牙连接丢失恢复

    MACBOOK用户可能会碰到一个神奇而无奈的问题: 某些情况下,很多时候从睡眠状态回来,会发现蓝牙设备再也无法连接,包括蓝牙鼠标.键盘等等... 恢复方法一般是,重启或注销后重新登陆,然后所有工作现场 ...

  4. mysql5.6修改密码并授权所有远程用户可登陆

    1.my.ini文件,删除最后一行的"skip-grant-tables 2.执行"use mysql;",使用mysql数据库; 3.执行:update mysql.u ...

  5. 【Qt开发】【Linux开发】Qt程序在嵌入式设备(arm) 上运行,鼠标擦除界面的解决方案

    笔者最近想在arm开发板上,开发一个应用程序,经过网上查询发现qt作为跨平台开发软件很不错,于是便选择了qt开发,笔者的qt版本是4.8.6的.由于arm的主频太低,在arm上进行开发编译,效率会大大 ...

  6. 第五周学习总结&第三次实验报告(String类的应用)

    第五周学习总结 1.学习了继承的相关知识点: (1) 继承的格式为class 子类 extends 父类{} (2) 继承实际上是通过子类去扩展父类的功能 (3) 一个子类只能继承一个父类,也就是说, ...

  7. Maven 中 resources 作用

    默认情况下,如果没有指定resources,目前认为自动会将src/main/resources下的.xml文件放到target里头的classes文件夹下的package下的文件夹里.如果设定了re ...

  8. [转帖]IIS7.5应用程序池集成模式和经典模式的区别介绍

    IIS7.5应用程序池集成模式和经典模式的区别介绍 之前转帖过一个 但是感觉不如这个说的细: https://www.jb51.net/article/31010.htm 关注脚本之家微信公众号(jb ...

  9. list 转 map java8

    // Arrays.asList("a:1.0", "b:2.0", "c:3.0") --> Map {a=1.0, b=2.0, ...

  10. ES6生成器与迭代器

    ES6迭代器的一个例子 function run(taskDef) { var task = taskDef(); var result = task.next(); // 递归执行迭代 functi ...