异或与
时间限制:C/C++/Rust/Pascal 1秒,其他语言2秒
空间限制:C/C++/Rust/Pascal 256 M,其他语言512 M
Special Judge, 64bit IO Format: %lld

题目描述

给你一个长度为 n 的序列 a,请你从中找到两个下标 i,j(i\neq j) ,满足 a_i\oplus a_j=2\times(a_i\;\&\;a_j)
其中 \oplus 为按位异或,
异或运算的规则是:
0\oplus0=0
0⊕1=1
1⊕0=1
1⊕1=0

\& 为按位与,
与运算的规则是:
1\&1=1
1\&0=0
0\&1=0
0\&0=0

输入描述:

第一行一个正整数 n(2\le n\le 10^5) 表示数列长度 
第二行 n 个整数 a_1,a_2,...,a_n\;\;(\forall i\in[1,n],0\le a_i\le 10^{18})

输出描述:

输出以空格分隔的两个正整数,表示你找到的下标
如果有多个合法答案,输出任意一个即可
如果没有,输出-1
示例1

输入

复制
3
9 18 27

输出

复制
1 3

说明

a_1=9,a_3=27 
a_1\oplus a_3=18=2\times(9)=2\times(a_1\;\&\;a_3)
满足要求