Time Limit: 1000 MS Memory Limit: 131072 K

Description

Misaka Mikoto is a main character of the Animation “To Aru Majutsu no Index” and “To Aru Kagaku no Railgun”.

She was enrolled into the Academy City to train herself and had been working very hard until she was ranked Level 5,

which is regarded as the highest ranking around the city.

By the way, there are only seven people who reached that level, and she won the third place. Now, she is the best “Electromaster” in Academy City.

Mikoto’s unique skill is to shoot metal objects such as coins at a high speed, destructively.

Hence, she finally gained a nickname, “Railgun” (超電磁砲 (レールガン) .

Mikoto attended Tokiwadai Middle School,which is a famous girls’ secondary school for the rich and elites and was acknowledged

as one of the five famous schools in the Academy City.

To most people, she is considered a typical lady, but in reality, she is short-tempered, prideful, and greatly interested in some childish things.

Misaka has many sisters, they are Misaka’s clones. Unlike Mikoto, they seem rather quiet and emotionless,

their voices are rather monotonous and computer-like, and they speak in third person by adding a description of themselves after every sentence.

In addition, they wear a special set of goggles that enables them to see electron beams and magnetic field lines for the reason that,

unlike Mikoto, they do not have that ability. Misaka clone No. 20001(Last order, 打ち止め, 最终之作).

She is the administrator of the Misaka Network and the fail-safe mechanism in case the Sisters go out of control.

She is not designed to function independently and survive for long outside a culture container and appears to be only about ten years old.

Misaka finds that all her sisters were trapped in a laboratory. Accelerator(一方通行 ,アクセラレータ) is going to kill them!!

She must take actions to save them. Last order tells her that she may not take all the sisters away.

Each sister has an electronic value a. If the GCD(Greatest Common Divisor) of some sisters’ value is greater than m

(if only one sister was chosen, the GCD is the electronic value of herself), then these sisters can be taken away.

Misaka wants to save as many sisters as possible. Please help her!!

Input

In the first line, there is an integer T, indicating the number of test cases.

The next T cases follow. For the first line, there are two integer n and m, n is the number of the sisters, m is the GCD limit.(1 <= n, m <= 1000000)

Then another line shows n integer, represents all the electronic values of all the sisiters.(1 <= values <= 1000000)

Output

Output one line for each test case.

Just print the max number of sisters which Misaka can save.

Sample Input

3

3 1

1 2 3

3 2

1 2 4

3 4

1 3 5

Sample Output

3

2

1

Hint

For the third case, Misaka can only choose the third sister.

#include<queue>
#include<stack>
#include<vector>
#include<math.h>
#include<cstdio>
#include<numeric>//STL数值算法头文件
#include<stdlib.h>
#include<string.h>
#include<iostream>
#include<algorithm>
#include<functional>//模板类头文件
using namespace std; const int INF=1e9+7;
const int maxn=1010000;
typedef long long ll; //(筛法的活用)
//首先这一道题讲的是n个数与m的关系,仔细想想
//如果某几个数的gcd是m,那么这几个数肯定是m的倍数,这就是筛法的巧妙之处
//既可以筛出素数,也可以筛出一个数的倍数,放在这一题中,从最小的m开始找,
//把从** m **到*** n个数中的最大数为终点 **范围内的所有m的倍数都找出来
//之前用桶排的思想把出现的数某个的** 次数 **记录下来,如果某个数
//** 是m的倍数,且在这n个数中 **,则把这个数的频数加起来,最后结果就是答案
int n,m,t;
int vis[maxn];
int main()
{
scanf("%d",&t);
while(t--)
{
memset(vis,0,sizeof(vis));
int maxx=0,a;
scanf("%d%d",&n,&m);
for(int i=0; i<n; i++)
{
scanf("%d",&a);
vis[a]++;
maxx=max(maxx,a);
}
int ans=0;
for(int i=m; i<=maxx; i++)
{
int cnt=0;
for(int j=1; j<=maxx; j++)
{
int temp=i*j;
if(temp>maxx)
break;
cnt+=vis[temp];
}
ans=max(cnt,ans);
}
printf("%d\n",ans);
}
return 0;
}

misaka and last order SCU - 4489 (筛法的灵活应用)的更多相关文章

  1. Heritrix源码分析(七) Heritrix总体介绍(转)

    本博客属原创文章,欢迎转载!转载请务必注明出处:http://guoyunsky.iteye.com/blog/642794         本博客已迁移到本人独立博客: http://www.yun ...

  2. 【转】SQL常用的语句和函数

    原文链接:http://www.cnblogs.com/mailingfeng/archive/2013/01/07/2850116.html order by 的数值型灵活使用 select * f ...

  3. SQL常用的语句和函数

    order by 的数值型灵活使用 select * from table_a where order by decode(函数,'asc',1,'desc',-1)*jsny; 控制试图的访问时间: ...

  4. 使用CSS灵活的盒子

    CSS3灵活的盒子,或flexbox,是一个布局模式提供页面上的元素的安排这样的元素表现可以预见当页面布局必须适应不同屏幕大小和不同的显示设备.对于许多应用程序,灵活的块盒模型提供了一个改进模型,它不 ...

  5. POJ 1087 A Plug for UNIX / HDU 1526 A Plug for UNIX / ZOJ 1157 A Plug for UNIX / UVA 753 A Plug for UNIX / UVAlive 5418 A Plug for UNIX / SCU 1671 A Plug for UNIX (网络流)

    POJ 1087 A Plug for UNIX / HDU 1526 A Plug for UNIX / ZOJ 1157 A Plug for UNIX / UVA 753 A Plug for ...

  6. POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离)

    POJ 2502 Subway / NBUT 1440 Subway / SCU 2186 Subway(图论,最短距离) Description You have just moved from a ...

  7. POJ 1797 Heavy Transportation / SCU 1819 Heavy Transportation (图论,最短路径)

    POJ 1797 Heavy Transportation / SCU 1819 Heavy Transportation (图论,最短路径) Description Background Hugo ...

  8. HDU 1686 Oulipo / POJ 3461 Oulipo / SCU 2652 Oulipo (字符串匹配,KMP)

    HDU 1686 Oulipo / POJ 3461 Oulipo / SCU 2652 Oulipo (字符串匹配,KMP) Description The French author George ...

  9. HDU 4489 The King’s Ups and Downs dp

    题目链接: http://acm.hdu.edu.cn/showproblem.php?pid=4489 The King's Ups and Downs Time Limit: 2000/1000 ...

随机推荐

  1. phpcms直接取子栏目的内容、调用点击量的方法

    子栏目里面的内容可以直接取,而不需要通过循环. {$CATEGORYS[$catid][catname]}//取子栏目的栏目名称 {$CATEGORYS[$catid][image]}//取子栏目的栏 ...

  2. bzoj 2303 并查集

    首先如果没有限制的话,我们可以直接求出答案,假设对于n*m的矩阵,我们最上方一行和左方的一列随意确定,那么首先这写确定的状态肯定是不会不合法的,因为我们可以调整剩下的01状态来使得这一行一列的状态合法 ...

  3. zedboard学习记录.1.纯PL流水灯

    环境:vivado 217.4 开发板: zedboard ver.d xc7z020clg484-1 1.打开Vivado新建一个RTL工程. 2.add source->add/create ...

  4. flask插件系列之flask_caching缓存

    前言 为了尽量减少缓存穿透,同时减少web的响应时间,我们可以针对那些需要一定时间才能获取结果的函数和那些不需要频繁更新的视图函数提供缓存服务,可以在一定的时间内直接返回结果而不是每次都需要计算或者从 ...

  5. C基础 如何让代码只执行一次

    1.0 最简单, 最高效的方式 C 代码运行起点 main 就是个大单例函数. 如果把函数注册在其里面, 那么一定很可以 :) // 某个库需要初始化的函数 void log_init(void) { ...

  6. linux系统查找具体进程

    ps -ef | grep '查找内容' eg:ps -ef | grep '测试USB设备穿透'

  7. PSQueue队列操作

    队列是一种特殊的线性表,特殊之处在于它只允许在表的前端(front)进行删除操作,而在表的后端(rear)进行插入操作,和栈(FILO,First In Last Out,先进后出)属于线性表一样,队 ...

  8. MySQL-IN和Exists区别

    1.in和exists in是把外表和内表作hash连接,而exists是对外表作loop循环,每次loop循环再对内表进行查询.一直以来认为exists比in效率高的说法是不准确的.  exists ...

  9. IndexWriterConfig的各个配置项说明(转)

    1.Analyzer:分析器 2.matchVersion:所用Lucene的版本 3.ramBufferSizeMB:随机内存 默认为16M. 用于控制buffer索引文档的内存上限,如果buffe ...

  10. droupout

    当训练样本比较少时,为了防止过拟合,可以丢掉一些节点的连接,让某些隐含层结点不工作(即停止更新权值),采用部分连接的方式. 参考:http://blog.csdn.net/on2way/article ...