蓝桥杯第八届真题:包子凑数

点击查看:蓝桥杯历年真题 题解目录

08.包子凑数

蓝桥杯第八届真题:包子凑数_第1张图片
蓝桥杯第八届真题:包子凑数_第2张图片

```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);
    }
}

你可能感兴趣的:(蓝桥杯历届真题,蓝桥杯,蓝桥杯竞赛,算法竞赛,java算法)