问题描述
给定一个由 n 个整数组成的序列 A:我们必须找到对的数量 (i,j)
where
(A[i] | A[j]) - (A[i] & A[j]) = (A[i] - A[j])
例如假设 A 是 {4,4,2,1} 所以总共存在 6 对
(1,1)
(2,2)
(1,2)
(2,1)
(3,3)
(4,4)
我的代码越来越少了。任何人都可以为这个问题提出更好的方法吗?
我的代码:
#include <bits/stdc++.h>
using namespace std;
#define ll long long int
#define mod 1000000007
int main()
{
int t;
cin >> t;
while (t--)
{
ll n;
cin >> n;
vector<ll> v1;
ll i,a,j;
for (i = 0; i < n; i++)
{
cin >> a;
v1.push_back(a);
}
ll sum = 0;
for (i = 0; i < n; i++)
{
for (j = 0; j < n; j++)
{
ll pp = v1[i] | v1[j];
ll qq = v1[i] & v1[j];
ll rr = v1[i] - v1[j];
if ((pp - qq) == rr)
{
// cout << i << " " << j << '\n';
sum++;
}
}
}
cout << sum << '\n';
}
}
解决方法
暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!
如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。
小编邮箱:dio#foxmail.com (将#修改为@)