第八个点re了,求大佬看看错在哪
查看原帖
第八个点re了,求大佬看看错在哪
135573
over_blue_sky楼主2020/8/21 14:42
#include<cstdio>
using namespace std;
int n,m,q[100001],w[100001],wz,e[100001],ans=0;
inline int read(){
	int s=0;
	char ch=getchar();
	while(ch<'0'||ch>'9')ch=getchar();
	while(ch>='0'&&ch<='9')s=s*10+ch-'0',ch=getchar();
	return s;
}
int main(){
	n=read();
	m=read();
	for(int i=1;i<=n;i++){
		e[i]=read();
		if(e[i]<=m)q[e[i]]++;
	}
	for(int i=1;i<=m;i++){
		if(!q[i])continue;
		for(int j=i;j<=m;j+=i)w[j]+=q[i];
	}
	for(int i=1;i<=m;i++){
		if(ans<w[i])ans=w[i],wz=i;
	}
	if(ans==0){
		printf("1 0\n");
		return 0;
	}
	printf("%d %d\n",wz,ans);
	for(int i=1;i<=n;i++){
		if(wz%e[i]==0)printf("%d ",i);
	}
	return 0;
}
2020/8/21 14:42
加载中...