算法设计 邮票问题
1. 问题描述
设有n种不同面值a1, a2,…, an的邮票,规定每封信最多贴m张邮票。对于给定的m,n,求出最大的邮资连续区间。例如,给定n=3,m=3,邮票面值分别为2, 3, 5,则最大的邮资连续区间为[2,13]。
2. 具体要求
Input
输入的第一行是一个正整数n,表示测试例个数。接下来几行是n个测试例的数据,每个测试例的数据由两行组成,其中第一行含两个正整数n和m (1<=n, m<=10),表示有n种邮票,每封信最多贴m张邮票;第二行含n个正整数,表示n种邮票的面值。同一行整数之间用一个空格隔开。
Output
对于每个测试例输出一行,含两个整数,依次为最大的邮资连续区间的下界和上界,当存在多个最大的邮资连续区间时,输出下界值最小的一个。同一行两个整数之间用一个空格隔开。
3. 测试数据
Sample Input
2
3 3
2 3 5
4 5
1 4 12 21
Sample Output
2 13
1 71
代码:
/// <summary>
/// 是否可以选出目标价值
/// </summary>
/// <param name="stamp">邮票面值</param>
/// <param name="n">邮票数组大小</param>
/// <param name="tar">目标价值</param>
/// <param name="m">最多可以选择的邮票张数</param>
/// <param name="find">是否找到目标价值的解</param>
/// <param name="count">当前已经选择的邮票张数</param>
/// <param name="cur">当前价值</param>
/// <param name="next">接下来要选择的邮票的价值</param>
void select(int* stamp, int n, int tar, int m, bool& find, int count, int cur, int next)
{

该博客探讨了邮票问题的算法设计,旨在找到最大邮资连续区间。问题描述涉及n种不同面值的邮票,每封信最多贴m张。针对输入的n个测试案例,给出包含n种邮票面值的两行数据,算法需要输出最大邮资区间。样例输入和输出展示了具体的操作过程,同时博客中可能包含了相关的代码实现。
最低0.47元/天 解锁文章
1261

被折叠的 条评论
为什么被折叠?



