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. android FragmentTabhost导航分页

    基本模板 public class MainActivity extends FragmentActivity { private FragmentTabHost mTabHost; private ...

  2. Linux操作系统--定时任务

    最近在学习Linux操作系统.学到了关于定时任务的章节,作为一个总结写下这篇文章.在Linux中,我们可以将耗时大的任务如复制大文件,压缩.解压缩大文件等放进定时任务中(深夜执行,因为工作时间访问量大 ...

  3. Docker创建JIRA 7.2.4中文破解版

    目录 目录 1.介绍 1.1.什么是JIRA? 2.JIRA的官网在哪里? 3.如何下载安装? 4.对JIRA进行配置 4.1.打开浏览器:http://localhost:20012 4.2.JIR ...

  4. 【原】Java学习笔记005 - 流程控制

    package cn.temptation; public class Sample01 { public static void main(String[] args) { // 程序的流程控制(流 ...

  5. Linux内存描述之高端内存--Linux内存管理(五)

    1. 内核空间和用户空间 过去,CPU的地址总线只有32位, 32的地址总线无论是从逻辑上还是从物理上都只能描述4G的地址空间(232=4Gbit),在物理上理论上最多拥有4G内存(除了IO地址空间, ...

  6. python3 多线程的使用

    示例1: import threadingfrom time import sleep class forThread(threading.Thread): def __init__(self, ev ...

  7. 南邮攻防训练平台逆向第四题WxyVM

    下载文件elf文件,运行输入flag,用ida打开逆向算法: 不是很复杂,可以看出flag长度需要24,最终会和已给出dword_601060进行比较,一致则成功,那么现在只需要看上面的sub_400 ...

  8. windows下安装MongoDB扩展和配置

    windows下安装MongoDB扩展和配置 1.下载mongoDB扩展,根据当前php版本进行下载 地址如下:http://pecl.php.net/package/mongo 我本地php版本是 ...

  9. centosFTP服务搭建及权限配置

    引用一个其他大佬对vsftpd的描述: vsftpd 是“very secure FTP daemon”的缩写,安全性是它的一个最大的特点. vsftpd 是一个 UNIX 类操作系统上运行的服务器的 ...

  10. mysql的分组

    以下是根据老师的视屏写的总结,要自己实际操作以下. 首先老师一顿操作猛如虎,得到以下的表. 然后进行以下的操作: 发现筛选时报错了,老师的解释实说,分组是因为mysql不知道选择谁而出现报错,因为pa ...