#CSES1654. 位运算问题

位运算问题

题目背景

翻译自 CSES-1654 题。

题目描述

给定一个包含 nn 个整数的列表,你的任务是为每个元素 xx 计算以下三个值:

  1. 有多少个元素 yy 满足 xy=xx \mid y = x (即 xx 能整除 yy)。
  2. 有多少个元素 yy 满足 x&y=xx \& y = x (即 xxyy 的按位与结果是 xx)。
  3. 有多少个元素 yy 满足 x&y0x \& y \neq 0 (即 xxyy 的按位与结果不为 00)。

输入格式

第一行包含一个整数 nn,表示列表的大小。

第二行包含 nn 个整数 x1,x2,,xnx_1, x_2, \ldots, x_n,表示列表中的元素。

输出格式

输出 nn 行,对于每个元素,分别输出上述三个值。

样例

5
3 7 2 9 2
3 2 5
4 1 5
2 4 4
1 1 3
2 4 4

数据范围

  • 1n2×1051 \le n \le 2 \times 10^5
  • 1xi1061 \le x_i \le 10^6