算法设计 邮票问题

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

算法设计 邮票问题

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)
{
   
   
	
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值