Comet OJ - Contest #12 D
题目描述
求(x,y)的对数满足x∈[0,a],y∈[0,b],x⊕y=0且|x-y|<=m
题解
一种比较sb的做法是考虑x-y的借位,根据借位以及差值进行转移
还有一种比较正常的做法,假设一开始x=0,y=n,那么就需要把y的某一些1移到x上,也就是对于(x-y)加上2^(i+1)
设加的数之和为s,那么需要保证|s-n|<=m,也就是n-m<=s<=n+m
注意是当n的第i位为1时才可以加上2^(i+1),把上界右移一位后就变成加上2^i
设f[i][0/1][0/1][0/1],表示当前到第i位,x、y、s是否顶住上界
枚举第i位的xy所选,使得x[i]^y[i]=n[i]且新的s不会越界即可
code
sb版
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#define fo(a,b,c) for (a=b; a<=c; a++)
#define fd(a,b,c) for (a=b; a>=c; a--)
#define min(a,b) (a<b?a:b)
using namespace std;
int a[60];
int b[60];
int x[60];
int y[60];
long long f[61][2][2][2][2];
int T,i,j,k,l,I,J,K,L,p,q,P,Q,fs,ll;
long long n,m,A,B,ans;
int swap(int &x,int &y)
{
int z=x;
x=y;
y=z;
}
void work()
{
memset(f,0,sizeof(f));
f[60][0][0][0][0]=1;
fd(i,60,1)
{
I=i-1;
fo(j,0,1)
{
fo(k,0,1)
{
fo(p,0,1)
{
fo(q,0,1)
if (f[i][j][k][p][q])
{
if (!a[I])
{
if (j && !b[I]) continue;
fo(l,0,1)
if ((p || x[I]>=l) && (q || y[I]>=l))
{
if (!j && b[I]>0) K=1; else K=k;
if (x[I]>l) P=1; else P=p;
if (y[I]>l) Q=1; else Q=q;
f[I][j][K][P][Q]+=f[i][j][k][p][q];
}
}
else
{
if (I==fs) ll=1;
else ll=0;
fo(l,ll,1)
if ((p || x[I]>=l) && (q || y[I]>=(1-l)))
{
if (!l)
{
if (!j)
J=0,K=1;
else
{
if (b[I])
J=0,K=k;
else
J=1,K=k;
}
}
else
{
if (j && !b[I]) continue;
if (k)
J=0,K=1;
else
{
if (!b[I])
{
if (j)
continue;
else
J=1,K=0;
}
else
{
if (j)
continue;
else
J=0,K=0;
}
}
}
if (x[I]>l) P=1; else P=p;
if (y[I]>(1-l)) Q=1; else Q=q;
f[I][J][K][P][Q]+=f[i][j][k][p][q];
}
}
}
}
}
}
}
fo(k,0,1)
{
fo(p,0,1)
{
fo(q,0,1)
ans+=f[0][0][k][p][q];
}
}
}
int main()
{
scanf("%d",&T);
for (;T;--T)
{
scanf("%lld%lld%lld%lld",&A,&B,&n,&m);
fs=-1;
fo(i,0,59)
{
a[i]=n&1;
n>>=1;
if (a[i])
fs=i;
}
if (fs==-1)
{
printf("%lld\n",min(A,B)+1);
continue;
}
fo(i,0,59) b[i]=m&1,m>>=1;
fo(i,0,59) x[i]=A&1,A>>=1;
fo(i,0,59) y[i]=B&1,B>>=1;
ans=0;
work();
fo(i,0,59)
swap(x[i],y[i]);
work();
printf("%lld\n",ans);
}
}
正常版
#include <bits/stdc++.h>
#define fo(a,b,c) for (a=b; a<=c; a++)
#define fd(a,b,c) for (a=b; a>=c; a--)
#define min(a,b) (a<b?a:b)
#define max(a,b) (a>b?a:b)
using namespace std;
int a[61];
int x[61];
int y[61];
int z[61];
long long f[61][2][2][2];
int T,i,j,k,l,I,J,K,L,s,S,X,Y,X2,Y2;
long long N,M,A,B,s1;
void turn(int *a,long long s)
{
int i;
fo(i,1,60)
a[i]=s%2,s/=2;
}
long long work(long long t)
{
long long ans=0;
if (t>=0)
{
t/=2;
turn(a,t);
}
else
return 0;
memset(f,0,sizeof(f));
f[60][0][0][0]=1;
fd(i,60,1)
{
I=i-1;
fo(j,0,1)
{
fo(k,0,1)
{
fo(l,0,1)
if (f[i][j][k][l])
{
if (j) X2=1; else X2=x[i];
if (k) Y2=1; else Y2=y[i];
fo(X,0,X2)
{
if (X<x[i]) J=1; else J=j;
fo(Y,0,Y2)
if ((X^Y)==z[i] && !(!l && X && !Y && !a[i]))
{
if (Y<y[i]) K=1; else K=k;
if ((X && !Y)<a[i]) L=1; else L=l;
f[I][J][K][L]+=f[i][j][k][l];
}
}
}
}
}
}
fo(j,0,1)
{
fo(k,0,1)
{
fo(l,0,1)
ans+=f[0][j][k][l];
}
}
return ans;
}
int main()
{
scanf("%d",&T);
for (;T;--T)
{
scanf("%lld%lld%lld%lld",&A,&B,&N,&M);
turn(x,A);
turn(y,B);
turn(z,N);
printf("%lld\n",work(N+M)-work(N-M-1));
}
}
Comet OJ - Contest #12 D的更多相关文章
- Comet OJ - Contest #12
B 整个表格其实是一些联通块,取反操作不能跨连通块.所以直接统计一下每个连通块内数字不对的个数是不是偶数即可 #include<iostream> #include<cstring& ...
- Comet OJ - Contest #2 简要题解
Comet OJ - Contest #2 简要题解 cometoj A 模拟,复杂度是对数级的. code B 易知\(p\in[l,r]\),且最终的利润关于\(p\)的表达式为\(\frac{( ...
- Comet OJ - Contest #2简要题解
Comet OJ - Contest #2简要题解 前言: 我没有小裙子,我太菜了. A 因自过去而至的残响起舞 https://www.cometoj.com/contest/37/problem/ ...
- Comet OJ - Contest #4--前缀和
原题:Comet OJ - Contest #4-B https://www.cometoj.com/contest/39/problem/B?problem_id=1577传送门 一开始就想着暴力打 ...
- Comet OJ - Contest #11 题解&赛后总结
Solution of Comet OJ - Contest #11 A.eon -Problem designed by Starria- 在模 10 意义下,答案变为最大数的最低位(即原数数位的最 ...
- Comet OJ - Contest #8
Comet OJ - Contest #8 传送门 A.杀手皇后 签到. Code #include <bits/stdc++.h> using namespace std; typede ...
- Comet OJ - Contest #13-C2
Comet OJ - Contest #13-C2 C2-佛御石之钵 -不碎的意志-」(困难版) 又是一道并查集.最近做过的并查集的题貌似蛮多的. 思路 首先考虑,每次处理矩形只考虑从0变成1的点.这 ...
- Comet OJ - Contest #13 「火鼠的皮衣 -不焦躁的内心-」
来源:Comet OJ - Contest #13 芝士相关: 复平面在信息学奥赛中的应用[雾 其实是道 sb 题??? 发现原式貌似十分可二项式定理,然后发现确实如此 我们把 \(a^i\) 替换成 ...
- Comet OJ - Contest #13 「佛御石之钵 -不碎的意志-」(hard)
来源:Comet OJ - Contest #13 一眼并查集,然后发现这题 tmd 要卡常数的说卧槽... 发现这里又要用并查集跳过访问点,又要用并查集维护联通块,于是开俩并查集分别维护就好了 一开 ...
随机推荐
- java驼峰法和下划线法字符串的相互转换
java驼峰法和下划线法字符串的相互转换 1 import java.util.regex.Matcher; import java.util.regex.Pattern; public class ...
- div 加滚动条 超过div宽度 自动换行 div居中
一.div 中加滚动条 一. <div style=" overflow:scroll; width:400px; height:400px;”></div> 记住宽 ...
- 对MPU6050坐标矩阵修改的学习
MPU6050是根据三轴陀螺仪和三轴加速度计数据通过DMP运算的出欧拉角.系统默认为水平放置, 但是实际使用过程中并不都是水平放置,有些特殊的场合,要求芯片竖直放置,这时候就不得 不修改MPU6050 ...
- 【VS开发】【图像处理】自动白平衡(AWB)算法---色温曲线
原文地址:http://blog.csdn.net/wzwxiaozheng/article/details/38434391 白平衡算法---色温曲线 本文大体讲解了白平衡的算法流程,适用于想了解和 ...
- mybatis返回List<Map>
mapperl.xml中: <select id="getAmount" parameterType="int" resultType="jav ...
- HTML简单介绍(个人角度)
之前对HTML的理解:HTML主要是标签组成,一对标签组成一个位置,在响应的位置内填写对应的内容. 1.编译工具 [ ] HTML需要编译工具?txt文档改后缀双击运行. [ ] 了解前端了一下前端, ...
- 洛谷 P1578 奶牛浴场 题解
题面 1.定义有效子矩形为内部不包含任何障碍点且边界与坐标轴平行的子矩形.如图所示,第一个是有效子矩形(尽管边界上有障碍点),第二个不是有效子矩形(因为内部含有障碍点). 2.极大有效子矩形:一个有效 ...
- MLS(移动最小二乘)
https://blog.csdn.net/weixin_41484240/article/details/81204113 https://blog.csdn.net/baidu_38127162/ ...
- Ubuntu下火狐浏览器播放视频出现解码问题
问题描述 点击视频播放按钮,视频不会出现缓冲条,也没任何提示,视频界面就一直是黑屏的状态.右键该视频界面,选择检查元素,点击控制台,发现如下问题: The video on this page can ...
- Jquery复习(四)之text()、html()、val()
三个简单实用的用于 DOM 操作的 jQuery 方法: text() - 设置或返回所选元素的文本内容 html() - 设置或返回所选元素的内容(包括 HTML 标记) val() - 设置或返回 ...