Souvenir Shop

魔幻题目,这谁搞得到啊...

考场上完全sb了写了个线段树合并,想必我是个复杂度分析都没学过的入门级选手

发现这个网格图dag它的出度最多只有2

如果按照先走朝上的一条边进行dfs走后续遍历,就是遍历完儿子再加自己,那么dfn大于它的一定不会比它低

然后再按照先走朝右的一个边走后续遍历,dfn2大于它的一定不会比它左

那么它可以到达的点满足\(\le dfn1_i,\le dfn2_i\)就可以了...

然后就是普及组随便统计一下的问题了...


Code:

#include <cstdio>
#include <cctype>
#include <cstring>
#include <algorithm>
const int N=3e5+10;
template <class T>
void read(T &x)
{
x=0;char c=getchar();
while(!isdigit(c)) c=getchar();
while(isdigit(c)) x=x*10+c-'0',c=getchar();
}
struct koito_yuu
{
int dfn1,dfn2,v,now;
bool friend operator <(koito_yuu a,koito_yuu b){return a.dfn1==b.dfn1?a.dfn2<b.dfn2:a.dfn1<b.dfn1;}
}yuu[N];
int s[N],ans[N],mi[N],vis[N];
int n,m,v[N],to[2][N],dfsclock,dx[N],dy[N];
void add(int x,int d)
{
while(x<=n) s[x]+=d,x+=x&-x;
}
int qry(int x)
{
int ret=0;
while(x) ret+=s[x],x-=x&-x;
return ret;
}
void dfs1(int now)
{
if(!now||vis[now]) return;
vis[now]=1;
dfs1(to[0][now]);
dfs1(to[1][now]);
yuu[now].dfn1=++dfsclock;
}
void dfs2(int now)
{
if(!now||vis[now]) return;
vis[now]=1;
dfs2(to[1][now]);
dfs2(to[0][now]);
yuu[now].dfn2=++dfsclock;
}
int main()
{
freopen("souvenir.in","r",stdin);
freopen("souvenir.out","w",stdout);
read(n),read(m);
for(int i=1;i<=n;i++) read(dx[i]),read(dy[i]),read(yuu[i].v),yuu[i].now=i,mi[i]=n+1;
for(int u,v,i=1;i<=m;i++)
{
read(u),read(v);
if(dx[u]==dx[v])
{
if(dy[u]>dy[v]) std::swap(u,v);
to[0][u]=v;
}
else
{
if(dx[u]>dx[v]) std::swap(u,v);
to[1][u]=v;
}
}
dfs1(1);
dfsclock=0;
memset(vis,0,sizeof vis);
dfs2(1);
std::sort(yuu+1,yuu+1+n);
for(int i=1;i<=n;i++)
{
if(mi[yuu[i].v]>yuu[i].dfn2)
{
add(mi[yuu[i].v],-1);
mi[yuu[i].v]=yuu[i].dfn2;
add(mi[yuu[i].v],1);
}
ans[yuu[i].now]=qry(yuu[i].dfn2);
}
for(int i=1;i<=n;i++) printf("%d\n",ans[i]);
return 0;
}

2019.3.26

Souvenir Shop 解题报告的更多相关文章

  1. poj分类解题报告索引

    图论 图论解题报告索引 DFS poj1321 - 棋盘问题 poj1416 - Shredding Company poj2676 - Sudoku poj2488 - A Knight's Jou ...

  2. CH Round #56 - 国庆节欢乐赛解题报告

    最近CH上的比赛很多,在此会全部写出解题报告,与大家交流一下解题方法与技巧. T1 魔幻森林 描述 Cortana来到了一片魔幻森林,这片森林可以被视作一个N*M的矩阵,矩阵中的每个位置上都长着一棵树 ...

  3. 二模13day1解题报告

    二模13day1解题报告 T1.发射站(station) N个发射站,每个发射站有高度hi,发射信号强度vi,每个发射站的信号只会被左和右第一个比他高的收到.现在求收到信号最强的发射站. 我用了时间复 ...

  4. BZOJ 1051 最受欢迎的牛 解题报告

    题目直接摆在这里! 1051: [HAOI2006]受欢迎的牛 Time Limit: 10 Sec  Memory Limit: 162 MBSubmit: 4438  Solved: 2353[S ...

  5. 习题:codevs 2822 爱在心中 解题报告

    这次的解题报告是有关tarjan算法的一道思维量比较大的题目(真的是原创文章,希望管理员不要再把文章移出首页). 这道题蒟蒻以前做过,但是今天由于要复习tarjan算法,于是就看到codevs分类强联 ...

  6. 习题:codevs 1035 火车停留解题报告

    本蒟蒻又来写解题报告了.这次的题目是codevs 1035 火车停留. 题目大意就是给m个火车的到达时间.停留时间和车载货物的价值,车站有n个车道,而火车停留一次车站就会从车载货物价值中获得1%的利润 ...

  7. 习题: codevs 2492 上帝造题的七分钟2 解题报告

    这道题是受到大犇MagHSK的启发我才得以想出来的,蒟蒻觉得自己的代码跟MagHSK大犇的代码完全比不上,所以这里蒟蒻就套用了MagHSK大犇的代码(大家可以关注下我的博客,友情链接就是大犇MagHS ...

  8. 习题:codevs 1519 过路费 解题报告

    今天拿了这道题目练练手,感觉自己代码能力又增强了不少: 我的思路跟别人可能不一样. 首先我们很容易就能看出,我们需要的边就是最小生成树算法kruskal算法求出来的边,其余的边都可以删掉,于是就有了这 ...

  9. NOIP2016提高组解题报告

    NOIP2016提高组解题报告 更正:NOIP day1 T2天天爱跑步 解题思路见代码. NOIP2016代码整合

随机推荐

  1. Registrator中文文档

    目录 快速入门 概述 准备 运行Registrator 运行Redis 下一步 运行参考 运行Registrator Docker选项 Registrator选项 Consul ACL令牌 注册URI ...

  2. OV摄像头图像采集基础知识总结

    目前FPGA用于图像采集 传输 处理 显示应用越来越多,主要原因是图像处理领域的火热以及FPGA强大的并行处理能力.本文以OV7725为例,对摄像头使用方面的基础知识做个小的总结,为后续做个铺垫. 下 ...

  3. typora快捷键

    目录 基础信息 常用快捷键 修改快捷键 基础信息 typora是一款极佳的markdown写作软件,编辑和预览两者合二为一,免费良心软件,推荐使用. 官网:https://www.typora.io/ ...

  4. Linux 下 C# Mono P/Invoke .so 动态链接库。

    linux 的动态链接库 libgw.so 的函数 如下: struct lbt_chan { uint32_t freq_hz; uint16_t scan_time_us; }; struct l ...

  5. 【导航】Python相关

    [博客导航] Python相关导航 [索引]Python常用资源(从新手到大牛) [任务]Python语言程序设计.MOOC学习 [笔记]Python集成开发环境——PyCharm 2018.3下载. ...

  6. Django REST framework基础:版本控制

    DRF的版本控制 为什么需要版本控制 API 版本控制允许我们在不同的客户端之间更改行为(同一个接口的不同版本会返回不同的数据). DRF提供了许多不同的版本控制方案. 可能会有一些客户端因为某些原因 ...

  7. 网络流 之 dinic算法

    我觉得这个dinic的算法和之前的增广路法差不多 .使用BFS对残余网络进行分层,在分层时,只要进行到汇点的层次数被算出即可停止, 因为按照该DFS的规则,和汇点同层或更下一层的节点,是不可能走到汇点 ...

  8. MYSQL中文乱码以及character_set_database属性修改

    新安装MYSQL,还没有修改数据库系统编码. 之后由于创建数据库时候:create database db_name; 没有指定编码,之后发现乱码就修改各个属性之后还是乱码,便开始配置数据库属性,之后 ...

  9. 【Git】+ 新建+删除+上传+覆盖

    上传代码时邮箱格式不符合:https://blog.csdn.net/u012558695/article/details/64921922 在本地新建一个分支: git branch newBran ...

  10. vue diff 算法学习

    function updateChildren (parentElm, oldCh, newCh, insertedVnodeQueue, removeOnly) { let oldStartIdx ...