CF1013B.And

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

There is an array with nn elements a1,a2,...,ana_{1},a_{2},...,a_{n} and the number xx .

In one operation you can select some ii ( 1<=i<=n1<=i<=n ) and replace element aia_{i} with a_{i}&x , where & denotes the bitwise and operation.

You want the array to have at least two equal elements after applying some operations (possibly, none). In other words, there should be at least two distinct indices iji≠j such that ai=aja_{i}=a_{j} . Determine whether it is possible to achieve and, if possible, the minimal number of operations to apply.

输入格式

The first line contains integers nn and xx ( 2<=n<=1000002<=n<=100000 , 1<=x<=1000001<=x<=100000 ), number of elements in the array and the number to and with.

The second line contains nn integers aia_{i} ( 1<=ai<=1000001<=a_{i}<=100000 ), the elements of the array.

输出格式

Print a single integer denoting the minimal number of operations to do, or -1, if it is impossible.

输入输出样例

  • 输入#1

    4 3
    1 2 3 7
    

    输出#1

    1
    
  • 输入#2

    2 228
    1 1
    

    输出#2

    0
    
  • 输入#3

    3 7
    1 2 3
    

    输出#3

    -1
    

说明/提示

In the first example one can apply the operation to the last element of the array. That replaces 7 with 3, so we achieve the goal in one move.

In the second example the array already has two equal elements.

In the third example applying the operation won't change the array at all, so it is impossible to make some pair of elements equal.

首页