C++ long long 异或
时间: 2023-09-25 21:14:13 浏览: 266
在C++中,long long 是一个数据类型,表示长整型。而异或运算符(^)用于对两个操作数进行位异或操作。
如果你想对两个 long long 类型的变量进行异或运算,可以使用以下方式:
```cpp
long long a = 10;
long long b = 5;
long long result = a ^ b;
```
在上述示例中,result 的值将为 15,因为 10 和 5 的二进制表示分别为 1010 和 0101,它们进行位异或运算后得到 1111,即十进制的 15。
请注意,如果你使用的是无符号的 long long 类型(unsigned long long),那么异或运算将对无符号数的每一位进行操作。
相关问题
tire树求最大最下异或和
题目描述
给定一棵 $n$ 个节点的二叉树,每个节点上有一个整数。求二叉树中某个子树内的最大和最小数的异或和。
输入格式
第一行包含整数 $n$。
以下 $n$ 行每行描述二叉树的一个节点,格式为 ID val lson rson,其中 ID 表示节点编号(范围 1∼n),val 是节点上的整数,lson 和 rson 分别表示该节点的左儿子和右儿子的编号。若节点没有左儿子或右儿子,则对应位置为 0。
输出格式
一个整数,表示异或和。
数据范围
1≤n≤10^5,−10^9≤val≤10^9
输入样例1:
5
1 1 2 3
2 2 4 5
3 3 0 0
4 4 0 0
5 5 0 0
输出样例1:
7
输入样例2:
9
1 1 2 3
2 2 4 5
3 3 6 7
4 4 8 9
5 5 0 0
6 6 0 0
7 7 0 0
8 8 0 0
9 9 0 0
输出样例2:
8
算法
(Trie 树,后缀数组,分块) $O(n log n + n \log^2 mod)$
C++ 代码
用Trie树实现
```
#include<iostream>
#include<cstring>
#include<algorithm>
#include<cstdio>
#include<stdlib.h>
#include<time.h>
using namespace std;
#define f(a,b,c) for(a=b;a<=c;a++)
#define g(a,b,c) for(a=b;a>=c;a--)
#define ll long long
const ll INF=2e9;
const int N=1e5+7,M=1e6+7;
inline int read(){
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9') {if(ch=='-') f=-1; ch=getchar();}
while(ch>='0'&&ch<='9') {x=(x<<1)+(x<<3)+ch-'0';ch=getchar();}
return x*f;
}
int e[M],ne[M],h[N],idx;
void add(int a,int b){e[idx]=b;ne[idx]=h[a];h[a]=idx++;}
int fa[N],dep[N],sz[N],son[N],wson[N],dfn[N],dnt,ndfn[N],tp[N];
struct Trie{
int son[2],cnt;
}tr[N*32];
int rt[N];
int cnt;
void update(int u,int k){
int p=rt[u],q=rt[cnt++];
int i,j;
rt[u]=q,tr[q]=tr[p];
f(i,30,0){
tr[q].cnt=tr[p].cnt+1;
j=(k>>i)&1;
if(tr[p].son[j]==0){
tr[q].son[0]=tr[p].son[0],tr[q].son[1]=tr[p].son[1];
tr[q].son[j]=cnt++,tr[tr[q].son[j]]=(Trie){0,0};
}
p=tr[p].son[j],q=tr[q].son[j];
}
tr[q].cnt=tr[p].cnt+1;
}
int query(int u,int v,int k){
int p=rt[u],q=rt[v],res=0;
int i,j;
f(i,30,0){
j=(k>>i)&1;
if(tr[tr[q].son[j^1]].cnt>tr[tr[p].son[j^1]].cnt) res=res|(1<<i),q=tr[q].son[j^1],p=tr[p].son[j^1];
else q=tr[q].son[j],p=tr[p].son[j];
}
return res;
}
void dfs1(int u,int la){
dep[u]=dep[la]+1,fa[u]=la,sz[u]=1;
int i,v,maxn=-1;
for(i=h[u];~i;i=ne[i]){
v=e[i];
if(v==la) continue;
dfs1(v,u);
sz[u]+=sz[v];
if(sz[v]>maxn) maxn=sz[v],son[u]=v;
}
}
void dfs2(int u){
int i,v;
dfn[u]=++dnt,ndfn[dnt]=u;
if(son[u]) wson[son[u]]=dfn[son[u]],tp[son[u]]=tp[u],dfs2(son[u]);
else return;
for(i=h[u];~i;i=ne[i]){
v=e[i];
if(v==fa[u]||v==son[u]) continue;
wson[v]=dfn[v],tp[v]=v,dfs2(v);
}
}
int find(int u,int v){
int f1=tp[u],f2=tp[v];
int ans=0;
while(f1!=f2){
if(dep[f1]<dep[f2]) swap(u,v),swap(f1,f2);
ans=max(ans,query(wson[f1],wson[u],v));
u=fa[f1],f1=tp[u];
}
if(u==v) return ans;
if(dep[u]<dep[v]) swap(u,v);
return max(ans,query(wson[son[v]],wson[u],v));
}
int main(){
int n=read();
memset(h,-1,sizeof h);
int i,a,b,c,ans1=0x3f3f3f3f,ans2=-0x3f3f3f3f;
f(i,1,n){
a=read(),b=read(),c=read();
if(c){
add(a,c),add(c,a);
add(b,c),add(c,b);
}
else{
add(a,b),add(b,a);
}
}
dfs1(1,0),wson[1]=dfn[1],tp[1]=1,dfs2(1);
rt[0]=cnt++,tr[rt[0]]=(Trie){0,0};
f(i,1,n){
a=ndfn[i];
rt[a]=rt[fa[a]];
update(a,read());
}
f(i,1,n){
a=ndfn[i];
ans1=min(ans1,query(rt[1],rt[a],read()));
ans2=max(ans2,query(rt[1],rt[a],read()));
}
cout<<ans1+ans2;
return 0;
}
```
'''
我只允许你用c++实现计算i,i+1,i+2,...r的异或和 输入格式: 输入包括两个整数1<=i,r<=1018 输出格式: 输出题目描述中的整数 输入样例: 3 6 输出样例 4
好的,那我用 C++ 重新实现一遍。同样是利用异或的性质,求出 i-1 和 r 的异或和,再将两者异或即可得到 i 到 r 的异或和。
下面是 C++ 代码实现:
```cpp
#include <iostream>
using namespace std;
int main() {
long long i, r;
cin >> i >> r;
// 求出 i-1 的异或和
long long xor_i_1 = 0;
for (int j = 0; j < 64; j++) {
if ((i-1) & (1LL<<j)) {
// 如果 i-1 的二进制表示的第 j 位为 1,则将 2^j 加入异或和
xor_i_1 ^= (1LL<<j);
}
}
// 求出 r 的异或和
long long xor_r = 0;
for (int j = 0; j < 64; j++) {
if (r & (1LL<<j)) {
// 如果 r 的二进制表示的第 j 位为 1,则将 2^j 加入异或和
xor_r ^= (1LL<<j);
}
}
// 计算 i 到 r 的异或和
long long xor_i_to_r = xor_i_1 ^ xor_r;
cout << xor_i_to_r << endl;
return 0;
}
```
注意,这里使用了 `1LL` 表示长整型数值 1,而 `1L` 只是表示长整型数值 1。因为题目中的数据范围比较大,所以需要使用长整型。
阅读全文