#P4411. [BJWC2010] 取数游戏

[BJWC2010] 取数游戏

题目描述

小 C 刚学了辗转相除法,正不亦乐乎,这小 P 又出来捣乱,给小 C 留了个 难题。 给 NN 个数,用 a1,a2,,ana_1,a_2, \cdots ,a_n来表示。现在小 P 让小 C 依次取数,第一个数可以 随意取。假使目前取得 aja_j,下一个数取ak(k>j)a_k(k>j),则aka_k必须满足gcd(aj,ak)L\mathrm{gcd}(a_j,a_k)≥L

到底要取多少个数呢?自然是越多越好! 不用多说,这不仅是给小 C 的难题,也是给你的难题。

输入格式

第一行包含两个数NNLL。 接下来一行,有 NN 个数用空格隔开,依次是 a1,a2,,ana_1,a_2,\cdots ,a_n

输出格式

仅包含一行一个数,表示按上述取法,最多可以取的数的个数。

5 6 
7 16 9 24 6
3

提示

样例解释

选取 33个数16,24,616,24,6gcd(16,24)=8\mathrm{gcd}(16,24)=8gcd(6,24)=6\mathrm{gcd}(6,24)=6

数据范围

30% 的数据N1000N≤1000
100% 的数据 N50000,2Lai1000000N≤50 000,2≤L≤a_i≤1 000 000