先前綴和一發,問題表示求[0-l2][0-r2]滿足條件的數的個數

假設可以把某一個數拆分成[前面任意個數][00…0-11…1(個數相同)]的區間

那麼問題會簡單的多,因為任意一個a位的整數分別xor[00…0(a個)-11…1(a個)]的結果會取遍00…0-11…1中的任意一個整數

這說明,我們拆出的區間大小都是2的冪次

很顯然想到x&-x操作,這個操作可以把某一個數最後的1去掉,從而新數和舊數形成的區間的大小是2的冪次

但是,x&-x操作是適用于區間開頭為1的情況,所以我們可以將要求的數加上1,記為b

這樣,b-1和b-b&-b就變成了一個合法的結尾為00…0-11…1的區間

我們可以枚舉每一個這樣子的區間,記00…0-11…1的長度,第一個區間為a,第二個為b

那麼異或起來的結果就是[兩個區間在max(a,b)之前的長度異或起來][max(a,b)個00…0-11…1]

這樣,問題就變成了求出連續區間中能被m整除的數的個數

實現上,我們可以枚舉a+1和b+1的每一個1位,則a+1在這一位後面和b+1在這一位後面的數全為00…0-11…1

然後我們可以把a和b的這一位去掉取前面的所有位,這樣可以計算出前面的部分

注意別忘記求出來的結果乘以另一個較短的位的00…0-11…1的數的個數

代碼:

#include<bits/stdc++.h>
using namespace std;
#define mo 998244353ll
typedef long long ll;
ll m;
ll get(ll l,ll r){
	if(l%m==0)return (r/m-l/m+1ll+mo)%mo;
	return (r/m-l/m+mo)%mo;
}
ll ct(ll a,ll b){
	ll ans=0;
	for(ll i=61;i>=0;i--)
		for(ll j=61;j>=0;j--)
			if((a&(1ll<<i))&&(b&(1ll<<j))){
				ll m1=max(i,j),m2=min(i,j);
				ll pre=((a^(1ll<<i))^(b^(1ll<<j)))&(~((1ll<<m1)-1ll));
				ll suf=pre+(1ll<<m1)-1ll;
				ans=(ans+get(pre,suf)*((1ll<<m2)%mo)%mo)%mo;
			}
	return ans;
}
int main(){
	freopen("mod.in","r",stdin);
	freopen("mod.out","w",stdout);
	ll a,b,c,d;
	scanf("%lld%lld%lld%lld%lld",&a,&b,&c,&d,&m);
	printf("%lld",(ct(b+1,d+1)-ct(b+1,c)-ct(a,d+1)+ct(a,c)+mo)%mo);
}

jzoj5894的更多相关文章

  1. JZOJ5894【NOIP2018模拟10.5】同余方程

    题目 Description

随机推荐

  1. 安全运维 -- Linux服务器使用公私钥密匙证书登录

    环境:Ubuntu 16 前言 黑客遍地都是,ssh/pop3/ftp等爆破工具的流行让站长的日常运维工作量大大加重.Metasplot,Bruter等工具更是针对以上协议有专门 的破解方法,有字典破 ...

  2. CentOS7下BIND配置主从服务器和缓存服务器

    系统环境:CentOS Linux release 7.4.1708 (Core)  3.10.0-693.el7.x86_64 软件版本:bind-chroot-9.9.4-51.el7_4.1.x ...

  3. PAT 1054 求平均值 (20)(代码+思路+测试用例)

    1054 求平均值 (20)(20 分) 本题的基本要求非常简单:给定N个实数,计算它们的平均值.但复杂的是有些输入数据可能是非法的.一个"合法"的输入是[-1000,1000]区 ...

  4. mysql 执行多线程临时方案

    sqr::IDatabase *db=NULL;IDbConnection *conn = NULL;int main(int argc, char* argv[]) { db = GetDataba ...

  5. numpy 命令 ravel 等

    xx.ravel()  :表示把一个矩阵行优先展成一个向量.跟flatten一样. import numpy as np print (np.c_[np.array([[1,2,3],[2,3,5]] ...

  6. java如何实现以数据流的形式下载压缩包到本地?

    先不多说,直接贴代码吧,在服务器的E盘下放一个E:/manual.rar的压缩包 package com.cellstrain.icell.controller; import org.springf ...

  7. Mybatis实现原理探究-实现部分Mybatis功能(上)

    一.前言: MyBatis 是一款优秀的持久层框架,它支持定制化 SQL.存储过程以及高级映射.MyBatis 避免了几乎所有的 JDBC 代码和手动设置参数以及获取结果集.MyBatis 可以使用简 ...

  8. Ubuntu14.04下安装Cuda8.0

    https://blog.csdn.net/sinat_19628145/article/details/60475696 https://developer.nvidia.com/cuda-down ...

  9. (KMP扩展 利用循环节来计算) Cyclic Nacklace -- hdu -- 3746

    http://acm.hdu.edu.cn/showproblem.php?pid=3746 Cyclic Nacklace Time Limit: 2000/1000 MS (Java/Others ...

  10. hdu 1205 吃糖果【鸽巢原理】

    题目 这道题不难,看别人博客的时候发现大家都说用鸽巢原理,这是个什么鬼,于是乎百度之. 1.把某种糖果看做隔板,如果某种糖果有n个,那么就有n+1块区域,至少需要n-1块其他种糖果才能使得所有隔板不挨 ...