买不到的数目

该博客介绍了如何利用裴蜀定理解决一个关于糖果包装的问题。小明的糖果店提供4颗和7颗装的水果糖,某些糖果数量无法通过这两种包装组合得到。文章通过分析和编程验证,揭示了当两个包装数量互质时,最大无法组合出的糖数的规律,并提供了AC代码。内容涉及小学数奥题、裴蜀定理和算法实现。
摘要由CSDN通过智能技术生成

买不到的数目

题目

小明开了一家糖果店。

他别出心裁:把水果糖包成4颗一包和7颗一包的两种。

糖果不能拆包卖。

小朋友来买糖的时候,他就用这两种包装来组合。

当然有些糖果数目是无法组合出来的,比如要买 10 颗糖。

你可以用计算机测试一下,在这种包装情况下,最大不能买到的数量是17。

大于17的任何数字都可以用4和7组合出来。

本题的要求就是在已知两个包装的数量时,求最大不能组合出的数字。

输入格式

两个正整数 n,m,表示每种包装中糖的颗数。

输出格式

一个正整数,表示最大不能买到的糖数。

数据范围

2 ≤ n , m ≤ 1000 ,
保证数据一定有解。

输入样例:
4 7
输出样例:
17
分析

这是一道很经典的小学数奥题,找出规律来就会非常简单啦!

那么根据题意可以分析得出,如果p和q的最大公约数大于1,那么是无解的,而如果p和q的最大公约数等于1,此时p和q互质,则一定有解

这里有一个定理——裴蜀定理:如果p和q的最大公约数是d的话,那么一定存在两个整数a和b,使得ap+bq=d

因此如果p和q互质,那么一定存在ap+bq=1,那么当要凑的数足够大时,amp+bmq=m,则a(m-q)p+(bm+p)q=m

下面就是关于打表找规律的代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>

using namespace std;

bool dfs(int m,int p,int q)
{
    if(!m)
    {
        return true;
    }
    
    if(m>=p&&dfs(m-p,p,q))
    {
        return true;
    }
    
    if(m>=q&&dfs(m-q,p,q))
    {
        return true;
    }
    
    return false;
}
int main()
{
    int p,q;
    cin>>p>>q;
    
    int res=0;
    for(int i=1;i<=1000;i++)
    {
        if(!dfs(i,p,q))
        {
            res=i;
        }
    }
    cout<<res<<endl;
    return 0;
}

规律:若p和q互质,(p-1)(q-1)-1=m

AC代码
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>

using namespace std;

int main()
{
    int p,q;
    cin>>p>>q;
    
    cout<<(p-1)*(q-1)-1<<endl;
    
    return 0;
}
关于本题的数学知识

(I am y总的搬运工hhh)
在这里插入图片描述
更多证明请参考大佬博客

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值