洛谷P2709小B的询问

  • 莫队裸题,模板题
  • 莫队就是把询问区间排个序,先按左端点的Pos排序(POS是分块那个数组),pos一样的按右端点排序
  • 代码:
     #include <bits/stdc++.h>
    #define nmax 50010 using namespace std;
    int a[nmax],ta[nmax],cnt[nmax]={};
    int n,m,qn,k;
    struct que{
    int l,r,p,id;
    bool operator < (const que& x) const{ return (x.p==p)?(x.r>r):(x.p>p); }
    }q[nmax]; int main(){
    scanf("%d%d%d",&n,&qn,&k);
    m=sqrt(n);
    for (int i=; i<=n; i++) scanf("%d",&a[i]);
    for (int i=; i<=qn; i++) {
    scanf("%d%d",&q[i].l,&q[i].r);
    q[i].p=(q[i].l-)/m;
    q[i].id=i;
    }
    sort(q+,q+qn+);
    int l=q[].l,r=q[].l-,ans=;
    for (int i=; i<=qn; i++) {
    while(l>q[i].l) l--,ans+=(*cnt[a[l]]+),cnt[a[l]]++;
    while(r<q[i].r) r++,ans+=(*cnt[a[r]]+),cnt[a[r]]++;
    while(l<q[i].l) ans-=(*cnt[a[l]]-),cnt[a[l]]--,l++;
    while(r>q[i].r) ans-=(*cnt[a[r]]-),cnt[a[r]]--,r--;
    ta[q[i].id]=ans;
    }
    for (int i=; i<=qn; i++) printf("%d\n",ta[i]);
    return ;
    }

    ヽ✿゜▽゜)ノ

BZOJ3289: Mato的文件管理

  • 莫队加树状数组
  • 每次区间长度增加的时候加上移动次数,减少的时候减去本来的移动次数(题意是只能移动相邻的嘛)
  • 移动次数就是在当前区间的排名辣(因为要移动到那里去嘛,这个用树状数组很好维护。
  • 没注意看题目,没有离散化re到死(果然人傻就是有各种各样的问题,嘤)
  • 代码:
     #include <bits/stdc++.h>
    #define lowbit(x) x&(-x)
    #define nmax 50005 using namespace std;
    typedef long long ll;
    int n,q,bn; //bn为每块的大小
    int data[nmax],c[nmax]={},lsh[nmax];
    ll ans[nmax]={};
    struct seg{
    int l,r,pl,id;
    bool operator < (const seg a) const{ return (a.pl==pl)?(a.r>r):(a.pl>pl); }
    }qes[nmax]; void upd(int x,int y){ //y决定是加是减
    while(x<=n) { c[x]+=y; x+=lowbit(x); }
    } int myfind(int x){
    int ans=;
    while(x>) { ans+=c[x]; x-=lowbit(x); }
    return ans;
    } bool mycmp(int a,int b){ return data[a]<data[b]; } int main(){
    cin>>n;
    bn=sqrt(n);
    for (int i=; i<=n; i++) { scanf("%d",&data[i]); lsh[i]=i; }
    sort(lsh+,lsh+n+,mycmp);
    for (int i=; i<=n; i++) data[ lsh[i] ]=i;
    cin>>q;
    for (int i=; i<=q; i++) {
    scanf("%d%d",&qes[i].l,&qes[i].r);
    qes[i].id=i;
    qes[i].pl=(qes[i].l-)/bn+;
    }
    sort(qes+,qes+q+);
    int l=qes[].l,r=qes[].l-,nowl=,ta=; //nowl现在该区间的长度
    for (int i=; i<=q; i++) {
    while(qes[i].l<l) l--,upd(data[l],),ta+=( myfind(data[l])- ),nowl++;
    while(qes[i].r>r) nowl++,r++,upd(data[r],),ta+=( nowl-myfind(data[r]) );
    while(qes[i].l>l) ta-=( myfind(data[l])- ),upd(data[l],-),nowl--,l++;
    while(qes[i].r<r) ta-=( nowl-myfind(data[r]) ),upd(data[r],-),nowl--,r--;
    ans[ qes[i].id ]=ta;
    }
    for (int i=; i<=q; i++) printf("%lld\n",ans[i]);
    return ;
    }

    (╯▔皿▔)╯

wa自动机 的 莫队 刷题记录的更多相关文章

  1. AC 自动机刷题记录

    目录 简介 第一题 第二题 第三题 第四题 第五题 第六题 简介 这就是用来记录我对于<信息学奥赛一本通 · 提高篇>一书中的习题的刷题记录以及学习笔记. 一般分专题来写(全部写一起可能要 ...

  2. CODEFORCES 340 XOR and Favorite Number 莫队模板题

    原来我直接学的是假的莫队 原题: Bob has a favorite number k and ai of length n. Now he asks you to answer m queries ...

  3. $2019$ 暑期刷题记录1:(算法竞赛DP练习)

    $ 2019 $ 暑期刷题记录: $ POJ~1952~~BUY~LOW, BUY~LOWER: $ (复杂度优化) 题目大意:统计可重序列中最长上升子序列的方案数. 题目很直接的说明了所求为 $ L ...

  4. PE刷题记录

    PE刷题记录 PE60 / 20%dif 这道题比较坑爹. 所有可以相连的素数可以构成一张图,建出这张图,在其中找它的大小为5的团.注意上界的估算,大概在1W以内.1W内有1229个素数,处理出这些素 ...

  5. [2009国家集训队]小Z的袜子(hose)(BZOJ2038+莫队入门题)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=2038 题目: 题意:中文题意,大家都懂. 思路:莫队入门题.不过由于要去概率,所以我们假 ...

  6. leetcode刷题记录--js

    leetcode刷题记录 两数之和 给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那 两个 整数,并返回他们的数组下标. 你可以假设每种输入只会对应一个答案.但 ...

  7. 清橙A1206.小Z的袜子 && CF 86D(莫队两题)

    清橙A1206.小Z的袜子 && CF 86D(莫队两题) 在网上看了一些别人写的关于莫队算法的介绍,我认为,莫队与其说是一种算法,不如说是一种思想,他通过先分块再排序来优化离线查询问 ...

  8. Leetcode刷题记录(python3)

    Leetcode刷题记录(python3) 顺序刷题 1~5 ---1.两数之和 ---2.两数相加 ---3. 无重复字符的最长子串 ---4.寻找两个有序数组的中位数 ---5.最长回文子串 6- ...

  9. 刷题记录:[HarekazeCTF2019]encode_and_encode

    目录 刷题记录:[HarekazeCTF2019]encode_and_encode 一.知识点 JSON转义字符绕过 php伪协议 刷题记录:[HarekazeCTF2019]encode_and_ ...

随机推荐

  1. lua学习之深入函数第二篇

    深入函数 2 非全局的函数 函数是第一类值,函数可以存储到全局变量,局部变量,table 字段中 lua 函数库中的大部分函数存储到 table 字段中 Lib = {} Lib.foo = func ...

  2. (1) Q#学习笔记 - 第一章 QDK安装

    2020/2/22,开始学习Q#. 第1章 QDK的安装 第1节 简介 QDK是Microsoft Quantum 开发工具包,可以进行量子编程,主要包含: Q# 编程语言 在 Q# 中对复杂功能进行 ...

  3. 如何避免FOUC,是如何产生的

    FOUC(Flash Of Unstyled Content)即浏览器样式闪烁或者叫做无样式内存闪烁(用户定义样式表加载之前浏览器使用默认样式显示文档,用户样式加载渲染之后再从新显示文档,造成页面闪烁 ...

  4. 「Flink」理解流式处理重要概念

    什么是流式处理呢? 这个问题其实我们大部分时候是没有考虑过的,大多数,我们是把流式处理和实时计算放在一起来说的.我们先来了解下,什么是数据流. 数据流(事件流) 数据流是无边界数据集的抽象 我们之前接 ...

  5. Powershell无文件挖矿查杀方法

    病毒现象 服务器出现卡顿.CPU飙升 和其他主机的445端口,建立起大量的连接 存在大量Powershell进程 病毒处置 封堵445端口; 或打永恒之蓝漏洞补丁(https://wukungt.gi ...

  6. Python 获取本地主机信息

    import wmi c = wmi.WMI() for sys in c.Win32_OperatingSystem(): #系统信息 print(sys.Caption) #系统版本号 print ...

  7. #《Essential C++》读书笔记# 第四章 基于对象的编程风格

    基础知识 Class的定义由两部分组成:class的声明,以及紧接在声明之后的主体.主体部分由一对大括号括住,并以分号结尾.主体内的两个关键字public和private,用来标示每个块的" ...

  8. IBM x3250m5安装redhat 6.5 加载raid卡驱动

    原文地址:http://www.i5i6.net/post/118.html 1. 下载对应raid卡驱动 for redhat6.5 x64(如本次x3250 m5 c100阵列卡驱动 lsi_dd ...

  9. modbus 协议说明及常用格式

    --- 说明: modbus协议一般适用于一个主设备访问多个从设备的硬件开发环境,类似于zigbee网络中的一个路由器多个协调器的一对多模型. modbus常用的寄存器类型为 3X 保持寄存器和 4X ...

  10. 《C++Primer》第五版习题答案--第六章【学习笔记】

    <C++Primer>第五版习题答案--第六章[学习笔记] ps:答案是个人在学习过程中书写,可能存在错漏之处,仅作参考. 作者:cosefy Date: 2020/1/16 第六章:函数 ...