#4051. 买不到的数目
- 2020 年 4 月 24 日
- 筆記
- 【鞭长驾远】从入门到喜爱
题目来源:
题目描述
小明开了一家糖果店。他别出心裁:把水果糖包成4颗一包和7颗一包的两种。糖果不能拆包卖。 小朋友来买糖的时候,他就用这两种包装来组合。当然有些糖果数目是无法组合出来的,比如要买 10 颗糖。 你可以用计算机测试一下,在这种包装情况下,最大不能买到的数量是17。大于17的任何数字都可以用4和7组合出来。 本题的要求就是在已知两个包装的数量时,求最大不能组合出的数字。
输入格式
输入两个正整数
输出格式
输出不能最大组合的数字
样例
Sample input
4 7
Sample Output
17
题目思路
像要你求最大,最小之类的题目大多数都是有技巧而言的,例如我们以后会碰到的贪心、动态规划、数论等思想。所以说我们要用数学的思维去找出最简单的方法。
要是硬解的话网上也有一大堆题解和对于数论公式的证明,那我重新写一遍也没什么意义了。
我是初学者,数论什么什么的都不知道,我只是隐隐约约的感觉到这个应该和什么公式有关。
然后我就用找规律的方法把它写出来了。
首先,先暴力一小部分,输出所有结果,
当然,写的时候也不是那么顺利,因为存在无解的情况存在,所以陷入了无限循环,然后我将将那些肯定不存在的情况排除了。
然后就出现了
我们要寻找的是ans=f(n,m),这样的函数;
通过不断试验发现:ans= n * m – n – m;
那么我们直接输出公式就好了。
#include <stdio.h> bool find(int m, int p, int q) { for(int i=0;i<1000;i++) for (int j = 0;j<1000;j++) if (p * i + j * q == m) return true; return false; } int main() { printf("n\tm\tans\n"); for (int i = 2;i <= 20;i++) for (int j = 2;j <= 20;j++) for (int k = 1000;k >= 0;k--) if (!find(k, i, j)) { if (k >= 999) break; //模拟的时候发现那些无解的数都符合这个条件,所以就用这个将其排除掉。 printf("%d\t%d\t%d\n", i, j, k); break; } return 0; }
寻找规律的代码。
#include <stdio.h> int main() { int n, m; scanf("%d %d", &n, &m); printf("%d\n", n * m - n - m); return 0; }
提交答案的代码
如果您觉得不错就点个推荐或者收藏吧!
此题为分支,其根为://www.cnblogs.com/Attacking-vincent/p/12721609.html