HDU 4325 离散化+树状数组 或者 不使用树状数组

时间:2022-09-08 20:18:35

题意:给出一些花的开放时间段,然后询问某个时间点有几朵花正在开放。

由于ti<1e9,我们需要先将时间离散化,然后将时间点抽象为一个数组中的点,显然,我们需要进行区间更新和单点查询,可以考虑线段树与树状数组两种做法,一般的,树状数组是用来维护区间和与单点修改的,那么,如何通过树状数组进行区间更新和单点查询呢,联想到差分数组,差分数组可以在o(1)的时间内进行区间的更新,但是单点查询的效率为o(n),显然不能用于处理此题,这时,考虑树状数组维护差分数组,就可以o(logn)地进行区间更新(更新差分数组的 l, r+1即可,使sub[l]++,sub[r+1]--),o(logn)地查询单点值(求差分数组前缀和)//树状数组维护差分数

#include<bits/stdc++.h

#define N 100005

#define mod 998244353
using namespace std;
typedef long long ll;
int sub[N<<],n,l[N],r[N],tim[N],nn;
int lowbit(int x){ return x&-x;};
int add(int x,int val)
{
while(x<=nn)
{
sub[x]+=val;
x+=lowbit(x);
}
}
int query(int x)
{
int ans=;
while (x>)
{
ans+=sub[x];
x-=lowbit(x);
}
return ans;
}
int main()
{
int t;
cin>>t;
for(int ca=;ca<=t;ca++)
{
memset(sub,, sizeof(sub));
vector<int>mp;
int q,L,R;
cin>>n>>q;
for(int i=;i<=n;i++)
{
scanf("%d%d",l+i,r+i);
mp.push_back(l[i]);
mp.push_back(r[i]);
}
for(int i=;i<=q;i++)
{
scanf("%d",tim+i);
mp.push_back(tim[i]);
}
nn=mp.size();
sort(mp.begin(),mp.end());
unique(mp.begin(),mp.end());
for(int i=;i<=n;i++)
{
L=lower_bound(mp.begin(),mp.end(),l[i])-mp.begin()+;
R=lower_bound(mp.begin(),mp.end(),r[i])-mp.begin()+;
add(L,);
add(R+,-);
}
//for(int i=1;i<=mp.size();i++)cerr<<query(i)<<endl;
printf("Case #%d:\n",ca);
for(int i=;i<=q;i++)
{
int pos=lower_bound(mp.begin(),mp.end(),tim[i])-mp.begin()+;
printf("%d\n",query(pos));
}
}
return ;
}

嘤嘤嘤~~博客写完,我就后悔了,本题的区间更新和单点查询操作是分开的,那么我为什么搞这么麻烦还用树状数组,直接差分数组求和后不就能o(1)单点查询了吗。。但是总体复杂度不变,仍为o(nlogn)
(n为离散化后,映射中点的个数,),常数降低了很多,,虽然运行时间只是由312ms到296ms,但是写起来简单了许多,以下是没有使用树状数组的ac代码

//树状数组维护差分数组
#include<bits/stdc++.h>
#define N 100005
#define mod 998244353
using namespace std;
typedef long long ll;
int sub[N<<],n,l[N],r[N],tim[N],nn;
int main()
{
int t;
cin>>t;
for(int ca=;ca<=t;ca++)
{
memset(sub,, sizeof(sub));
vector<int>mp;
int q,L,R;
cin>>n>>q;
for(int i=;i<=n;i++)
{
scanf("%d%d",l+i,r+i);
mp.push_back(l[i]);
mp.push_back(r[i]);
}
for(int i=;i<=q;i++)
{
scanf("%d",tim+i);
mp.push_back(tim[i]);
}
nn=mp.size();
sort(mp.begin(),mp.end());
unique(mp.begin(),mp.end());
for(int i=;i<=n;i++)
{
L=lower_bound(mp.begin(),mp.end(),l[i])-mp.begin()+;
R=lower_bound(mp.begin(),mp.end(),r[i])-mp.begin()+;
sub[L]++;
sub[R+]--;
}
for(int i=;i<=nn;i++)sub[i]+=sub[i-];
printf("Case #%d:\n",ca);
for(int i=;i<=q;i++)
{
int pos=lower_bound(mp.begin(),mp.end(),tim[i])-mp.begin()+;
printf("%d\n",sub[pos]);
}
}
return ;
}

事实证明,只要多思考,问题就会更简单。算是一点小小的启发吧



HDU 4325 离散化+树状数组 或者 不使用树状数组的更多相关文章

  1. HDU 6203 ping ping ping(dfs序&plus;LCA&plus;树状数组)

    http://acm.hdu.edu.cn/showproblem.php?pid=6203 题意: n+1 个点 n 条边的树(点标号 0 ~ n),有若干个点无法通行,导致 p 组 U V 无法连 ...

  2. hdu 1166 敌兵布阵——(区间和)树状数组&sol;线段树

    pid=1166">here:http://acm.hdu.edu.cn/showproblem.php?pid=1166 Input 第一行一个整数T.表示有T组数据. 每组数据第一 ...

  3. HDU - 1166 树状数组模板(线段树也写了一遍)

    题意: 汉语题就不说题意了,用到单点修改和区间查询(树状数组和线段树都可以) 思路: 树状数组的单点查询,单点修改和区间查询. 树状数组是巧妙运用二进制的规律建树,建树就相当于单点修改.这里面用到一个 ...

  4. R - Weak Pair HDU - 5877 离散化&plus;权值线段树&plus;dfs序 区间种类数

    R - Weak Pair HDU - 5877 离散化+权值线段树 这个题目的初步想法,首先用dfs序建一颗树,然后判断对于每一个节点进行遍历,判断他的子节点和他相乘是不是小于等于k, 这么暴力的算 ...

  5. 【BZOJ】1146&colon; &lbrack;CTSC2008&rsqb;网络管理Network(树链剖分&plus;线段树套平衡树&plus;二分 &sol; dfs序&plus;树状数组&plus;主席树)

    http://www.lydsy.com/JudgeOnline/problem.php?id=1146 第一种做法(时间太感人): 第二种做法(rank5,好开心) ================ ...

  6. 【Hihocoder 1167】 高等理论计算机科学 (树链的交,线段树或树状数组维护区间和)

    [题意] 时间限制:20000ms 单点时限:1000ms 内存限制:256MB 描述 少女幽香这几天正在学习高等理论计算机科学,然而她什么也没有学会,非常痛苦.所以她出去晃了一晃,做起了一些没什么意 ...

  7. POJ 1804 Brainman&lpar;5种解法,好题,【暴力】,【归并排序】,【线段树单点更新】,【树状数组】,【平衡树】&rpar;

    Brainman Time Limit: 1000MS   Memory Limit: 30000K Total Submissions: 10575   Accepted: 5489 Descrip ...

  8. Vijos P1448 校门外的树【多解,线段树,树状数组,括号序列法&plus;暴力优化】

    校门外的树 描述 校门外有很多树,有苹果树,香蕉树,有会扔石头的,有可以吃掉补充体力的…… 如今学校决定在某个时刻在某一段种上一种树,保证任一时刻不会出现两段相同种类的树,现有两个操作: K=1,K= ...

  9. SPOJ DQUERY树状数组离线or主席树

    D-query Time Limit: 227MS   Memory Limit: 1572864KB   64bit IO Format: %lld & %llu Submit Status ...

随机推荐

  1. React&period;js实现原生js拖拽效果及思考

    一.起因&思路 不知不觉,已经好几天没写博客了...近来除了研究React,还做了公司官网... 一直想写一个原生js拖拽效果,又加上近来学react学得比较嗨.所以就用react来实现这个拖 ...

  2. Java for LeetCode 030 Substring with Concatenation of All Words【HARD】

    You are given a string, s, and a list of words, words, that are all of the same length. Find all sta ...

  3. HTML超出文本显示省略号&period;&period;&period;&lbrack;text-overflow&rsqb;

    需要对div或者span同时应用Css: text-overflow:ellipsis; white-space:nowrap; overflow:hidden; 即可实现所想要得到的溢出文本显示省略 ...

  4. jQuery网页元素拖拽插件

    效果说明:配合已有CSS样式,载入插件后,网页元素可以随意在窗口内拖拽,设置了原位置半透明和拖拽半透明的效果选项,可根据需要选择.另外,当页面上有多个可拖拽元素时,可以载入另外一个用于设置z-inde ...

  5. J2EE 项目 org&period;apache&period;jasper&period;JasperException&colon; 解决方法

    项目从一个电脑转移到另一台电脑总是有各种意外qaq~ 刚放假把从实验室的项目拷回自己的电脑回家继续coding,结果出了这个错误.... 各个地方都调试原来是Tomcat版本问题!!!我电脑上的是6. ...

  6. nohup—后端守护进程

    要将一个命令放到后台执行,我们一般使用nohup sh command & 为什么要nohup? 因为我用使用Scrt这种终端工具退出的时候会向我们在当前shell下启动的进程发生一个SIGH ...

  7. 末学者笔记--NFS服务和DHCP服务讲解

    NFS服务端概述 一.概念: NFS,是Network File System的简写,即网络文件系统.网络文件系统是FreeBSD支持的文件系统中的一种,也被称为NFS:NFS允许一个系统在网络上与他 ...

  8. 12、多线程&colon;Threading、守护线程

    线程与进程: 线程对于进程来说,就好似工厂里的工人,分配资源是分配到工厂,工人再去处理. 线程是被系统独立调度和分派的基本单位,线程自己不拥有系统资源,只拥有一点儿在运行中必不可少的资源,但它可与同属 ...

  9. Git提交新项目

    Github或者码云上新建项目 $ git init $ git add * $ git remote add origin https://gitee.com/demo/demo.git $ git ...

  10. spring包下载方法

    http://blog.csdn.net/liangtiaoxian/article/details/52780747 https://jingyan.baidu.com/article/2fb0ba ...