首先要知道 (m/1 + m/2 + ... + m/m) 约为 mlogm

还有一个比较明显的结论,如果一个纪念品区间长度大于d,那么如果列车的停车间隔小于等于d,则这个纪念品一定能被买到

然后把区间按长度排序

枚举d,边枚举边加那些长度小于d的区间到线段树当中,这样可以保证一个纪念品不会被加2次

最后输出答案即可

#include <iostream>
#include <algorithm>
using namespace std;
const int Maxn = *;
namespace seqtree
{
struct Tree
{
Tree *ch[];
long long _v, label;
int Num, _l, _r, mid;
Tree() { _v = label = ; Num = ; }
void update();
void maintain();
}Node[Maxn], *null, *Root;
int tot = , _k, _L, _R;
long long v;
void Tree::update()
{
if(!label) return;
_v += Num*label;
if(Num != ) ch[]->label += label, ch[]->label += label;
label = ;
}
void Tree::maintain()
{
ch[]->update(); ch[]->update();
_v = ch[]->_v + ch[]->_v;
}
void protect()
{
null = new Tree();
null->ch[] = null->ch[] = null; null->Num = ;
}
void insert(Tree *&o, int l, int r)
{
int mid = (l+r)/;
if(o == null)
{
o = &Node[tot++];
o->ch[] = o->ch[] = null;
o->_l = l; o->_r = r; o->mid = (l+r)/;
}
if(l == r) { o->_v = v; return; }
if(_k <= mid) insert(o->ch[], l, mid);
else insert(o->ch[], mid+, r);
o->maintain(); o->Num = o->ch[]->Num + o->ch[]->Num;
}
Tree* Build(int n, long long *a)
{
protect(); Root = null;
for(int i = ; i <= n; i++) _k = i, v = a[i], insert(Root, , n);
return Root;
}
long long query(Tree *o)
{
long long ans = ;
o->update();
if(_L <= o->_l && o->_r <= _R) return o->_v;
if(_L <= o->mid) ans += query(o->ch[]);
if(_R > o->mid) ans += query(o->ch[]);
return ans;
}
long long Query(int L, int R) { _L = L; _R = R; return query(Root); }
void change(Tree *o)
{
o->update();
if(_L <= o->_l && o->_r <= _R) { o->label += v; o->update(); return; }
if(_L <= o->mid) change(o->ch[]); if(_R > o->mid) change(o->ch[]);
o->maintain();
}
void Change(int L, int R, int V) { _L = L; _R = R; v = V; change(Root); }
};
using namespace seqtree; struct Data
{
int l, r, v;
bool operator < (const Data &B) const
{ return v < B.v; }
}A[Maxn]; int n, m, l, r;
long long a[Maxn], ANS[Maxn];
int main()
{
cin.sync_with_stdio(false);
cin>>n>>m;
Build(m+, a);
for(int i = ; i < n; i++)
{
cin>>A[i].l>>A[i].r;
A[i].v = A[i].r - A[i].l + ;
}
sort(A, A+n);
int k = ;
for(int i = ; i <= m; i++)
{
for(; A[k].v < i && k < n; k++) Change(A[k].l, A[k].r, );
int ans = n - k;
for(int j = i; j <= m; j += i) ans += Query(j, j);
cout<<ans<<endl;
}
}

arc068 E: Snuke Line的更多相关文章

  1. ARC068E - Snuke Line

    原题链接 题意简述 给出个区间和.求对于任意,有多少个区间包含的倍数. 题解 考虑怎样的区间不包含的倍数. 对于的倍数和,满足的区间不包含任何的倍数. 于是转化为二维数点问题,可以用可持久化线段树解决 ...

  2. AtCoder Regular Contest 068E:Snuke Line

    题目传送门:https://arc068.contest.atcoder.jp/tasks/arc068_c 题目翻译 直线上有\(0-m\)这\(m+1\)个点,一共有\(m\)辆火车.第\(i\) ...

  3. 【AtCoder - 2300】Snuke Line(树状数组)

    BUPT2017 wintertraining(15) #9A 题意 有n个纪念品,购买区间是\([l_i,r_i]\).求每i(1-m)站停一次,可以买到多少纪念品. 题解 每隔d站停一次的列车,一 ...

  4. 【arc068E】Snuke Line

    Portal -->arc068E (温馨提示:那啥..因为各种奇怪的我也不知道的原因这题的题号在某度上面显示出来是agc007F...然而下面是arc068E的题解qwq给大家带来不便之处真是 ...

  5. [arc086e]snuke line

    题意: 有n个区间,询问对于$1\leq i\leq m$的每个i,有多少个区间至少包含一个i的倍数? $1\leq N\leq 3\times 10^5$ $1\leq M\leq 10^5$ 题解 ...

  6. 【AtCoder】ARC068

    ARC 068 C - X: Yet Another Die Game 显然最多的就是一次6一次5 最后剩下的可能需要多用一次6或者6和5都用上 #include <bits/stdc++.h& ...

  7. AtCoder Regular Contest

    一句话题解 因为上篇AGC的写的有点长……估计这篇也短不了所以放个一句话题解方便查阅啥的吧QwQ 具体的题意代码题解还是往下翻…… ARC 058 D:简单容斥计数. E:用二进制表示放的数字,然后状 ...

  8. NOIp模拟赛三十

    心态崩了的一天 先Orz yrx 开场五分钟yrx大吼一声:“这B题不是原题吗” hjw:“对哦好像我也做过哦” 过了十分钟yrx又大吼一声:“这C题我也做过啊,洪水那题啊” 于是 像我这种傻逼A题一 ...

  9. Snuke's Subway Trip

    すぬけ君の地下鉄旅行 / Snuke's Subway Trip Time limit : 3sec / Memory limit : 256MB Score : 600 points Problem ...

随机推荐

  1. js 判断两个时间相差的天数

    judgeDay(sDate1, sDate2) { const sDate1 = `${new Date(sDate1).getFullYear()}-${new Date(sDate1).getM ...

  2. Spring笔记1

    Spring Spring特点 1. 方便解耦,简化开发 通过Spring提供的IoC容器,我们可以将对象之间的依赖关系交由Spring进行控制,避免硬编码所造成的过度程序耦合.有了Spring,用户 ...

  3. 【tp5.1】微信公众号授权登录及获取信息录入数据库

    微信公众号开发文档链接:https://mp.weixin.qq.com/wiki?t=resource/res_main&id=mp1445241432 微信公众号授权登录分为两种: 1.以 ...

  4. jquery 节点

    $("ul li:eq(3)")  // 元素的index位置工0开始计数,所以这里的3实际为第4个元素 $("ul").find("li" ...

  5. Hadoop(21)-数据清洗(ELT)简单版

    有一个诸如这样的log日志 去除长度不合法,并且状态码不正确的记录 LogBean package com.nty.elt; /** * author nty * date time 2018-12- ...

  6. python 推导式的用法

    推导式看了不少,可每次都有新发现 例子1:返回满足条件为真,否则为假 try_list = [1, 2, 3, 4, 5] # 前2种一样, [a > 3 for a in b] [True i ...

  7. Android开发——Android系统启动以及APK安装、启动过程

    0. 前言   从Android手机打开开关,到我们可以使用其中的app时,这个启动过程到底是怎么样的? 1.  系统上电 当给Android系统上电,在电源接通的瞬间,CPU内的寄存器和各引脚均会被 ...

  8. android去掉button默认的点击阴影

    查了资料,发现别人都是说加一个style属性. style="?android:attr/borderlessButtonStyle" 加上了确实管用,但是我绝不是不求甚解的人.追 ...

  9. C++学习002-C++代码中插入汇编语句

    在C++中我们有时会遇到使用汇编语言的情况,这时可以在前面加上关键字“_asm”宏. 如下示例 编写环境 :vs2015 int main() { __asm mov al, 0x20; __asm ...

  10. Python全栈 正则表达式(概念、、语法、元字符、re模块)

    前言:        普通人有三件东西看不懂:医生的处方,道士的鬼符,程序员得正则表达式       什么是正则表达式? 正则表达式,又称规则表达式,英文名为Regular Expression,在代 ...