区间不好做,但是我们可以转化成前缀来做。转化为前缀之后之后就是二维前缀和。

但是我还是不怎么会做。所以只能去看吉老师的题解 (确定写的那么简单真的是题解???)。

我们要求模一个数余0,就等于找它的倍数。找它的倍数自然只要知道区间就可以了。

题解上面说:如果\(r1=2^n\),\(r2=2^m\),不妨设 \(n<=m\),那么结果一定在区间 \([0,2^n)\)中,而 且每一个值出现了 \(2^m\) 次

这是很显然的,因为按照异或的运算法则来讲,不可能会有比r1最高位1还高的位出现。而且考虑在二进制下,还有多种不同的方式可以凑成这个数。

之后我们考虑更一般的情况。

我们把高位确定下来,之后摆放低位。两两之间统计答案。

怎么理解呢,就是先把最高位的1确定下来,然后后面显然1就可以随便放了(反正使得当前位1变成0,后面(比它小的)的所有数都可以达到了)。我们考虑遍历枚举的两个边界的最高位1的位数,然后计算这种组合能够达到的范围(啊啊啊语文能力又下线了。。。怎么办。。大家看一下代码???),知道范围之后就容易能够知道有多少个所求数的倍数了。之后按照上面解释的,我们可以统计出有多少种不同的x,y组合方式达到这个异或值。

因为感觉自己说的很不清楚,所以代码里加了一点注释qwq。

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#define mod 998244353
#define ll long long
using namespace std;
ll kkk,ans,a,b,c,d;
ll calc(ll a,ll b){
ll ansans=0;
for(int i=0;i<=63;++i)
{
//因为在long long范围内,所以遍历到63
if(((a>>i)&1)==0) continue;
//如果该位不是1就跳过
for(int j=0;j<=63;++j)
{
if(((b>>j)&1)==0) continue;
//同上
ll l=((a-(1ll<<i))^(b-(1ll<<j)))&(~((1ll<<max(i,j))-1));
//因为我们已经确定max(i,j)为最高位1了
//所以前面的值就不变了,直接异或就行
//后面的max(i,j)位经过处理全变成0(与操作和后面的东西就是这个用)
//&(~((1<<n)-1))表示将后面的n位全部变成0
ll r=l+(1ll<<max(i,j))-1;
//因为是左闭右开区间
ll cnt=(r/kkk)-l/kkk+(l%kkk==0);
//注意左闭,所以如果正好是倍数的话还是要加上1
tmp%=mod;
ansans=(ansans+(cnt*((1LL<<min(i,j))%mod))%mod)%mod;
//注意及时取模qwq
//其实像我这样写不好,最好分步写,避免中间没有取模爆long long
//哦,还要注意左移右移的运算级很低,所以即使加括号
}
}
return ansans;
}
int main()
{
freopen("ce.in","r",stdin);
scanf("%lld %lld %lld %lld %lld",&a,&b,&c,&d,&kkk);
ll ans=calc(b+1,d+1);
ans=(ans+mod-calc(c,b+1))%mod;
ans=(ans+mod-calc(a,d+1))%mod;
ans=(ans+calc(a,c))%mod;
//类比二维前缀和
printf("%lld\n",ans%mod);
return 0;
}

牛客网提高组模拟赛第五场 T1同余方程(异或)(位运算)的更多相关文章

  1. nowcoder(牛客网)提高组模拟赛第四场 解题报告

    T1 动态点分治 就是模拟..... 但是没有过!! 看了题解之后发现.... 坑点:有可能 \(x<=r\),但是

  2. 牛客网提高组模拟赛第七场 T3 洞穴(附bitset介绍)

    就是DP. 我们可以很简单的想到要枚举中间点,进行边数的转移. 但是因为边长数据范围很大,所以我们考虑log的倍增. 状态设计为\(dp[i][j][k]\),为从节点\(i\)走\(2^k\)步能否 ...

  3. 牛客网提高组模拟赛第七场 T2 随机生成树

    其实看懂题就很水啦qwq,就是求\(1-N\)的约数啦. 暴力求的话时间复杂度是\(O(NlogN)\)的,其实正解是枚举每个数的倍数......这样的时间复杂度是\(\frac{N}{1}+\fra ...

  4. nowcoder(牛客网)提高组模拟赛第一场 解题报告

    T1 中位数(二分) 这个题是一个二分(听说是上周atcoder beginner contest的D题???) 我们可以开一个数组b存a,sort然后二分b进行check(从后往前直接遍历check ...

  5. nowcoder(牛客网)普及组模拟赛第一场 解题报告

    蒟蒻我可能考了一场假试 T1 绩点 这题没什么好说的,应该是只要会语言的就会做. T2 巨大的棋盘 一个模拟题吧qwq,但是要注意取模的时候先加上n或者m再取模,要不然会错的. #include< ...

  6. 计蒜客NOIP2017提高组模拟赛(五)day1-展览

    传送门 发现这题选或不选对状态的优劣程度不会产生影响,如果已经确定了两个数a和b,那么最优的首项和公比也都是唯一确定的, 与对于后面的数x,加进去也好不加进去也好,首项和公比依旧是原来的 于是我们用尺 ...

  7. 计蒜客NOIP2017提高组模拟赛(五)day1-机智的 AmyZhi

    传送门 很水的题目啦QAQ #include<cstdio> #include<cstdlib> #include<algorithm> #include<c ...

  8. 计蒜客NOIP2017提高组模拟赛(五)day2-蚂蚁搬家

    传送门 这题可以用线段树来维护 #include<cstdio> #include<cstdlib> #include<algorithm> #include< ...

  9. 计蒜客NOIP2017提高组模拟赛(五)day2-成绩统计

    传送门 用hash,因为map的复杂度可能在这题中因为多一个log卡掉,但是hash不会 可能因为这个生成的随机数有循环的情况,不是完全均匀的 而且这题hash表的长度也可以开的很大 #include ...

随机推荐

  1. 4.2 最邻近规则分类(K-Nearest Neighbor)KNN算法应用

    1 数据集介绍:   虹膜     150个实例   萼片长度,萼片宽度,花瓣长度,花瓣宽度 (sepal length, sepal width, petal length and petal wi ...

  2. PHP - 引用计数

    引用计数以及是否是引用变量,一个神奇的函数,查看当前引用计数: <?php xdebug_debug_zval('a'); 以上例程会输出: a: (refcount=1, is_ref=0)= ...

  3. Windows安装Mysql5.7.22

    1.下载Mysql,5.7版本,将zip包解压到某个安装目录下面,最好不要放C盘,选择一个容量大的磁盘.下载地址:https://dev.mysql.com/downloads/mysql/ 2.进入 ...

  4. 使用JavaScript调用aspx后台代码

    方法1:js同步调用 触发: onclick="javascript:share('<%# Eval("id_File") %>')" 页面函数: ...

  5. java web 读取配置文件两种方法

    package com.tsinghua.getDataBaseConn; import java.io.IOException;import java.io.InputStream;import j ...

  6. Android 多分辨率多屏幕适配

    请参见文章:http://blog.csdn.net/jiangxinyu/article/details/8598046 文章描述非常清晰.

  7. Listview getItemViewType的使用

    ListView中有两个可以用来让ListView可以在视图中显示多种布局的方法,分别是getItemType和getViewTypeCount 其中 getItemViewType返回的是有参数po ...

  8. linux系统文件的链接

    一. 硬链接(实际链接) (以linux系统为例) 1. 文件的索引节点inode 假设我们在硬盘当前目录下建立了一个名为mytext文本文件,其内容只有一行:This is my file. (1) ...

  9. Oracle和Mysql的区别 转载

    一.并发性 并发性是oltp数据库最重要的特性,但并发涉及到资源的获取.共享与锁定. mysql:mysql以表级锁为主,对资源锁定的粒度很大,如果一个session对一个表加锁时间过长,会让其他se ...

  10. 美化input type=range标签滑动样式(带渐变效果)

    input原来的样式就不在此赘述了: 下面看一下实际项目中用到的input输入框,同步绑定输入数据,实现输入框双向绑定(实际项目中使用的是vue框架): html部分: <div class=& ...