码迷,mamicode.com
首页 > 其他好文 > 详细

AC日记——Broken BST codeforces 797d

时间:2017-05-11 11:38:48      阅读:161      评论:0      收藏:0      [点我收藏+]

标签:map   dfs   turn   fine   inf   algo   main   ffffff   tchar   

D - Broken BST

 

思路:

  二叉搜索树;

  它时间很优是因为每次都能把区间缩减为原来的一半;

  所以,我们每次都缩减权值区间。

  然后判断dis[now]是否在区间中;

 

代码:

#include <map>
#include <cstdio>
#include <cstring>
#include <iostream>
#include <algorithm>

using namespace std;

#define maxn 100005
#define INF 0x7fffffff

int n,ch[maxn][2],dis[maxn],ans;
int l[maxn],r[maxn],root;

bool if_[maxn];

map<int,int>ma;
map<int,bool>maa;

inline void in(int &now)
{
    int if_z=1;now=0;
    char Cget=getchar();
    while(Cget>9||Cget<0)
    {
        if(Cget==-) if_z=-1;
        Cget=getchar();
    }
    while(Cget>=0&&Cget<=9)
    {
        now=now*10+Cget-0;
        Cget=getchar();
    }
    now*=if_z;
}

void dfs(int now,int l,int r)
{
    if(l>r) return ;
    if(dis[now]>=l&&dis[now]<=r)
    {
        if(!maa[dis[now]])
        {
            ans+=ma[dis[now]];
            maa[dis[now]]=true;
        }
    }
    if(ch[now][0]!=-1) dfs(ch[now][0],l,min(dis[now]-1,r));
    if(ch[now][1]!=-1) dfs(ch[now][1],max(l,dis[now]+1),r);
}

int main()
{
    in(n);
    for(int i=1;i<=n;i++)
    {
        in(dis[i]),in(ch[i][0]),in(ch[i][1]),ma[dis[i]]++;
        if(ch[i][0]!=-1) if_[ch[i][0]]=true;
        if(ch[i][1]!=-1) if_[ch[i][1]]=true;
    }
    for(int i=1;i<=n;i++)
    {
        if(!if_[i])
        {
            root=i;
            break;
        }
    }
    dfs(root,0,INF);
    cout<<n-ans;
    return 0;
}

 

AC日记——Broken BST codeforces 797d

标签:map   dfs   turn   fine   inf   algo   main   ffffff   tchar   

原文地址:http://www.cnblogs.com/IUUUUUUUskyyy/p/6839656.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!