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 要卡常数的说卧槽... 发现这里又要用并查集跳过访问点,又要用并查集维护联通块,于是开俩并查集分别维护就好了 一开 ...
随机推荐
- CTF—攻防练习之HTTP—SQl注入(get)
攻击机:192.168.32.152 靶机 :192.168.32.157 扫描靶机扫端口: 开放了ssh和80看下ssh版本有没有漏洞,searchsplot下,没有发现 dirb扫描下目录,有个a ...
- LeetCode.1021-删除最外面的括号(Remove Outermost Parentheses)
这是小川的第380次更新,第408篇原创 01 看题和准备 今天介绍的是LeetCode算法题中Easy级别的第242题(顺位题号是1021).有效的括号字符串为空(""),&qu ...
- 分布式锁中的基于redis的setnx的原理以及set和setnx的区别是什么
基于Redis实现分布式锁.虽然网上介绍的Redis分布式锁博客比较多,却有着各种各样的问题,本篇博客将详细介绍如何正确地使用setnx实现Redis分布式锁 这里就不介绍错误的示范了 大家直接看正确 ...
- Apache编译安装及LAMP架构
1.apache三种工作模式 1)prefork工作模式 一个进程处理一个用户请求 稳定但是不适合高并发的生产环境 2)worker工作模式 一个进程生成多个线程 合适高并发环境但是需要考虑到线程的安 ...
- sklearn.preprocessing.StandardScaler数据标准化
原文链接:https://blog.csdn.net/weixin_39175124/article/details/79463993 数据在前处理的时候,经常会涉及到数据标准化.将现有的数据通过某种 ...
- js if(!!!e) {} 判断条件中的三个感叹号什么意思
两个感叹号的意思就是,将变量转换为其对应的布尔值. !!e就是e对应的布尔值,true或者false. !!!e==!(!!e)==!true/!false=false/true;
- 学习Linux第一周记
2019/11/25 服务器硬件详述1) CPU 作用:运算/控制 关注信息 :路数 服务器中CPU的颗数 一般有 (单路 双路 ...
- Qt - 基于TCP的网络编程
TCP(传输控制协议 Transmission Control Protocol) 可靠.面向数据流.面向连接 的传输协议.(许多应用层协议都是以它为基础:HTTP.FTP) 使用情况: 相比UDP ...
- JavaScript中:地址引用的特性,导致静态初始值被修改
问题分类 JavaScript,值引用,地址引用 问题描述 开发过程中,服务端将静态配置数据从mysql数据库中读取到内存中,方便调用. 在实现流派功能时,需从数据库中读取流派种类数据到内存中,由于其 ...
- Hbase 0.92.1 Replication
原集群 服务器名称 服务 sht-sgmhadoopnn-01 Master,NameNode,JobTracker sht-sgmhadoopdn-01 RegionServer,DataNode, ...