点击查看:蓝桥杯历年真题 题解目录
08.包子凑数
```java
1.由扩展欧几里算法
ax + by + cz = m ; 当m不是gcd(a,b,c)的倍数时,无解。
<"对本题而言:若输入的数不互质,则凑不出的数有无数个">
2.对任何整数 a,b 和他们的最大公约数d,关于未知数 x和 y的线性丢番图方程(称为裴蜀等式):
ax + by = m 有整数解时,当且仅当m是d的倍数。
3. 裴蜀等式 有解时必然有无穷多个整数解,每组解x,y都称为裴蜀数
4. 当最大公约数为1时,即互质
如果 某个数能凑出,那么它加上任意一个输入的包子数,都能凑出
so,从零到10000扫描n次 ,逐个检查是否能凑出
import java.util.Scanner;
public class Main{
// 计算两个数的最大公约数
static int gcd1 (int a,int b){
return b==0?a:gcd1(b,a%b);
}
// 计算多个数的最大公约数
static int gcd2(int [] a){
int n = a.length;
int L = a[0];
for(int i=1;i<n;i++)
L = gcd1(L,a[i]);
return L;
}
public static void main(String[] args) {
// TODO Auto-generated method stub
Scanner in = new Scanner(System.in);
int n = in.nextInt();
int [] a = new int[n];
boolean []b = new boolean [10000];
b[0] = true;
for(int i=0;i<n;i++) {
a[i]=in.nextInt();
}
int gcd = gcd2(a);
/* 如果最大公约数不为1,一定有无数个数凑不出来
* 例如 , 多个数的最大公约数为2 ,则所以的 奇数都凑不出
*/
if(gcd!=1) {
System.out.println("INF");
System.exit(0); // 输出"INF"终止程序
}else {
/* 当最大公约数为1时,即互质
* 如果 某个数能凑出,那么它加上任意一个输入的包子数,都能凑出
so,从零到10000扫描n次 ,逐个检查是否能凑出 */
for(int i = 0;i<n;i++) {
for(int j=0;j+a[i]<10000;j++) {
if(b[j]) b[j+a[i]] = true;
}
}
}
int count = 0; //计数,记录凑不出的数
for(int i=0;i<10000;i++) {
if(b[i]==false) count++;
}
System.out.println(count);
}
}