A86021.LJJ 爱数书

省选/NOI-

通过率:0%

时间限制:4.00s

内存限制:256MB

题目描述

LJJ 的家里有一本「数书」,也就是说里面全都是数字的书,LJJ 十分喜爱它。

数书里有一个序列 AA,每次操作可以使一段连续的区间加 11 或减 11 并对 KK 取模(K1K-111 后变为 000011 后变为 K1K-1),我们定义和谐函数 F(A,K)F(A,K) 表示最少的操作次数,使得序列的所有元素都变为 00

例如 A={3,3,2,3},K=4A=\{3,3,2,3\},K=4 时,通过把 AA 变成 {0,0,3,0}\{0,0,3,0\},再把 AA 变成 {0,0,0,0}\{0,0,0,0\} 就能达到要求,所以 F(A,K)=2F(A,K)=2

现在,输入长度为 nn 的序列 AA,设 Al,rA_{l,r} 表示序列 AAll 个位置到第 rr 个位置的连续子序列。有 mm 次询问,每次询问输入 l,r,Kl,r,K,求 F(Al,r,K)F(A_{l,r},K) 的值。

输入格式

第一行两个整数 n,mn,m,表示序列长度为 nn,有 mm 次询问;
第二行有 nn 个整数,第 ii 个整数表示 AiA_i
第三至第 m+2m+2 行,每行三个整数 l,r,Kl,r,K

输出格式

mm 行,每行一个整数,表示每组询问的答案。

输入输出样例

  • 输入#1

    7 2
    8 8 8 0 8 8 8
    1 7 9
    3 5 17

    输出#1

    2
    16
  • 输入#2

    4 1
    5 3 8 2
    1 4 9

    输出#2

    8
  • 输入#3

    10 10
    7 7 6 5 5 2 8 5 0 3
    1 8 11
    3 10 11
    4 7 12
    9 10 12
    3 5 10
    2 7 10
    7 9 10
    2 7 11
    1 4 11
    4 7 10

    输出#3

    12
    15
    9
    3
    5
    8
    5
    9
    6
    7

说明/提示

对于 10%10\% 的数据,n10,m=1,K10n\le 10,m=1,K\le 10
对于 30%30\% 的数据,n1000,m=1,K230n\le 1000,m=1,K\le 2^{30}
对于 50%50\% 的数据,n2×105,m=1,K230n\le 2\times 10^5,m=1,K\le 2^{30}
另有 10%10\% 的数据,n2×105,m105,K=2n\le 2\times 10^5,m\le 10^5,K=2
另有 20%20\% 的数据,n,m3×104,K230n,m\le 3\times 10^4,K\le 2^{30}
对于全部数据,1n2×105,1m105,K230,1lrn1\le n\le 2\times 10^5,1\le m\le 10^5,K\le 2^{30},1\le l\le r\le n,保证 K>max{A1,A2,,An}K\gt \max \{A_1,A_2,\cdots ,A_n\}

首页