题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4638

题意:给出一个数列,若干询问。每次询问区间[L,R]的最少有多少段?每一段是连续的一段且这段内的数字也是连续的。

思路:对于新加入一个数字x,若之前x-1和x+1都已经加入了,那么总段数减1,若都没有加入,则总段数加1,若只加入一个,则总段数不变。然后,我们将数列分成 sqrt(n)段,将询问按照左端点放到相应的段中。同一段中按照右端点升序排序。那么在同一段中,右侧最多移动长度n左侧最左移动sqrt(n)。

struct node
{
    int L,R,id;
    
    void get()
    {
        RD(L,R);
        L--; R--;
    }
    
    int operator<(const node &a) const
    {
        return R<a.R;
    }
};

node a[N];
int n,m,d[N],ans[N],h[N];

vector<node> V[505];

int main()
{
    rush()
    {
        RD(n,m);
        int i,len=sqrt(n+1.0),cnt=(n+len-1)/len;
        FOR0(i,cnt) V[i].clear();
        FOR0(i,n) RD(d[i]);
        FOR1(i,m) 
        {
            a[i].get(),a[i].id=i;
            V[a[i].L/len].pb(a[i]);
        }
        FOR0(i,cnt) sort(V[i].begin(),V[i].end());
        
        int x,j,k=1,t,l,r;
        FOR0(i,cnt)
        {
            l=i*len; r=l-1; x=0; clr(h,0);
            FOR0(j,SZ(V[i]))
            {
                while(r<V[i][j].R)
                {
                    t=d[++r];
                    if(h[t-1]&&h[t+1]) x--;
                    else if(!h[t-1]&&!h[t+1]) x++;
                    h[t]=1;
                }
                while(l>V[i][j].L) 
                {
                    t=d[--l];
                    if(h[t-1]&&h[t+1]) x--;
                    else if(!h[t-1]&&!h[t+1]) x++;
                    h[t]=1;
                }
                while(l<V[i][j].L)
                {
                    t=d[l++];
                    if(h[t-1]&&h[t+1]) x++;
                    else if(!h[t-1]&&!h[t+1]) x--;
                    h[t]=0;
                }

ans[V[i][j].id]=x;
            }
        }
        FOR1(i,m) PR(ans[i]);
    }
}

HDU 4638 Group(分组)的更多相关文章

  1. hdu 4638 Group

    http://acm.hdu.edu.cn/showproblem.php?pid=4638 问题其实就是求[L,R]中有多少个连续的段 若每一个人都是一个段 那么[L,R]中每一个朋友关系就会减少一 ...

  2. HDU 4638 Group 【树状数组,分块乱搞(莫队算法?)】

    根据题目意思,很容易得出,一个区间里面连续的段数即为最少的group数. 题解上面给的是用树状数组维护的. 询问一个区间的时候,可以一个一个的向里面添加,只需要判断a[i]-1 和 a[i]+1是否已 ...

  3. HDU 4638 Group (线段树 | 树状数组 + 离线处理)

    Group Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  4. HDU 4638 Group (2013多校4 1007 离线处理+树状数组)

    Group Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others)Total Submi ...

  5. hdu 4638 Group(离线+树状数组)

    Group Time Limit: 4000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Subm ...

  6. HDU 4638 Group 树状数组 + 思路

    实际上就是问这个区间编号连续的段的个数,假如一个编号连续的段有(a+b)个人,我把他们分在同一组能得到的分值为(a+b)^2,而把他们分成人数为a和b的两组的话,得到的分值就是a^2+b^2,显然(a ...

  7. HDU 4638 Group ★(树状数组)

    题意 询问一段区间里的数能组成多少段连续的数. 思路 先考虑从左往右一个数一个数添加,考虑当前添加了i - 1个数的答案是x,那么可以看出添加完i个数后的答案是根据a[i]-1和a[i]+1是否已经添 ...

  8. hdu 4638 Group 莫队算法

    题目链接 很裸的莫队, 就不多说了... #include<bits/stdc++.h> using namespace std; #define pb(x) push_back(x) # ...

  9. HDU 4638 Group(莫队)题解

    题意:n个数,每个数有一个值,每次询问一个区间,问你这个区间能分成连续的几段(比如7 1 2 8 就是两端 1 2 和 7 8) 思路:莫队.因为L.R移动顺序wa了20发...问了一下别人,都是先扩 ...

随机推荐

  1. 设计模式之状态模式(State)

    状态模式原理:随着状态的变化,对象的行为也发生变化 代码如下: #include <iostream> #include <string> #include <list& ...

  2. hdu 3157 Crazy Circuits 网络流

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3157 You’ve just built a circuit board for your new r ...

  3. Leetcode#87 Scramble String

    原题地址 两个字符串满足什么条件才称得上是scramble的呢? 如果s1和s2的长度等于1,显然只有s1=s2时才是scramble关系. 如果s1和s2的长度大于1,那么就对s1和s2进行分割,划 ...

  4. ASP.NET Web.Config配置数据库连接的一种方法

    所谓的webConfig配置数据库连接就是在里面某个特定名称的节点中写下ADP.NET中的ConnectString,就这么简单 1.首先在Web.Config文件里写下数据库连接字符串. <c ...

  5. Git 10 周年之际,创始人 Linus Torvalds 访谈

    点这里 十年前的这一周,linux 内核社区面临一个根本性的挑战:他们不再能够使用他们的修复控制系统:BitKeeper,同时其他的软件配置管理遇到了对分布式系统的新需求.Linus Torvalds ...

  6. JS获取Url参数的通用方法

    //获取URL中的参数 function request(paras) { var url = location.href.replace('#', ''); var paraString = url ...

  7. zoj 3057 Beans Game 博弈论

    思路:三维DP,刚开始用记忆化搜索,MLE…… 后来改为直接预处理所有的情况. 总之就是必败态的后继是必胜态!!! 代码如下: #include<iostream> #include< ...

  8. java对象群体的组织:Enumeration及Iterator类

    在一般情况下,遍历集合类会使用一下方式: for(int i=0;i<v.size();i++)< p=""> Customer c=(Custormer)v.g ...

  9. UVALive 6187 Never Wait for Weights 带权并查集

    题意:每次给出每两个数之间的大小差值.在给出关系的过程中插入询问:数a和数b的差值,若不能确定,输出UNKNOWN 解法:相对大小关系的处理:并查集 1.给出两点的相对大小关系后,找到两个点的根节点, ...

  10. 简易解说拉格朗日对偶(Lagrange duality)(转载)

    引言:尝试用最简单易懂的描述解释清楚机器学习中会用到的拉格朗日对偶性知识,非科班出身,如有数学专业博友,望多提意见! 1.原始问题 假设是定义在上的连续可微函数(为什么要求连续可微呢,后面再说,这里不 ...