菜单 学习猿地 - LMONKEY

VIP

开通学习猿地VIP

尊享10项VIP特权 持续新增

知识通关挑战

打卡带练!告别无效练习

接私单赚外块

VIP优先接,累计金额超百万

学习猿地私房课免费学

大厂实战课仅对VIP开放

你的一对一导师

每月可免费咨询大牛30次

领取更多软件工程师实用特权

入驻
154
0

Wannafly 22A

原创
05/13 14:22
阅读数 41009

题解

另g = gcd(a1,a2,a3....)
那么k * g % m的方案书就是答案
这个式子子显然是有循环节的
x * g = 0 mod m ,x * g + y * m = 0
exgcd 后 x = x0 + k * (m/gcd(g,m)) 也是就m/gcd(g,m)

代码

#include<map> 
#include<cstdio> 
#include<algorithm> 
using namespace std; 
int n,m; 
int a[1007]; 
int gcd(int x,int y) { 
    if(!y) return x; 
    else return gcd(y,x % y); 
} 
int main() { 
	int n ,m;
	scanf("%d%d",&n,&m); int cnt = 0; 
    for(int i = 1;i <= n;++ i) {scanf("%d",a + i);if(a[i] > m)cnt ++; } 
    int num = m; 
    for(int i = 1;i <= n;++ i) num = gcd(a[i],num); 
    int ans = 0; 
	if(m % num) ans = (m / num) ; 
	else ans = m / num; 
	printf("%d\n",ans); 
    return 0; 
} 

发表评论

0/200
154 点赞
0 评论
收藏