Magic Coupon (25)

本文介绍了一道关于魔法优惠券的算法题目,旨在通过合理的策略选取优惠券与商品搭配,以实现收益最大化。文章提供了完整的代码实现,并采用了贪心算法进行求解。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Magic Coupon (25)

时间限制 1000 ms 内存限制 65536 KB 代码长度限制 100 KB 判断程序 Standard (来自 小小)
题目描述
The magic shop in Mars is offering some magic coupons. Each coupon has an integer N printed on it, meaning that when you use this coupon with a product, you may get N times the value of that product back! What is more, the shop also offers some bonus product for free. However, if you apply a coupon with a positive N to this bonus product, you will have to pay the shop N times the value of the bonus product… but hey, magically, they have some coupons with negative N’s!

For example, given a set of coupons {1 2 4 -1}, and a set of product values {7 6 -2 -3} (in Mars dollars M) where a negative value corresponds to a bonus product. You can apply coupon 3 (with N being 4) to product 1 (with value M7) to get M28 back; coupon 2 to product 2 to get M12 back; and coupon 4 to product 4 to get M3 back. On the other hand, if you apply coupon 3 to product 4, you will have to pay M$12 to the shop.
Each coupon and each product may be selected at most once. Your task is to get as much money back as possible

输入描述:
Each input file contains one test case. For each case, the first line contains the number of coupons NC, followed by a line with NC coupon integers. Then the next line contains the number of products NP, followed by a line with NP product values. Here 1<= NC, NP <= 105, and it is guaranteed that all the numbers will not exceed 230.

输出描述:
For each test case, simply print in a line the maximum amount of money you can get back.

输入例子:
4
1 2 4 -1
4
7 6 -2 -3

输出例子:
43

题解:给出两个集合,然后选取元素使乘积最大,可以想到贪心策略,把两个数组从小到大排序, 然后从左到右选取相同位置都是负数相乘,从右到左选取相同位置非负数相乘,然后便可以得到最大值。
平台是牛客,数据比较大,记得使用long long 类型。

#include <bits/stdc++.h>
#include <stdlib.h>
using namespace std;
#define vi vector<int>
#define pii pair<int,int>
#define x first
#define y second
#define all(x) x.begin(),x.end()
#define pb push_back
#define mp make_pair
#define SZ(x) x.size()
#define rep(i,a,b) for(int i=a;i<b;i++)
#define per(i,a,b) for(int i=b-1;i>=a;i--)
#define pi acos(-1)
#define mod 1000000007
#define inf 1000000007
#define ll long long
#define DBG(x) cerr<<(#x)<<"="<<x<<"\n";
#define N 200010
template <class U,class T> void Max(U &x, T y){if(x<y)x=y;}
template <class U,class T> void Min(U &x, T y){if(x>y)x=y;}
template <class T> void add(int &a,T b){a=(a+b)%mod;}
const int maxn=100001;
int n,m;
ll a1[maxn],a2[maxn];
int main()
{
    cin>>n;
    rep(i,0,n) scanf("%lld",&a1[i]);
    cin>>m;
    rep(i,0,m) scanf("%lld",&a2[i]);
    sort(a1,a1+n);
    sort(a2,a2+m);
    int  i=0,j=0;
    ll ans=0;
    while(a1[i]<0&&a2[i]<0&&i<n&&i<m)
    {
        ans+=a1[i]*a2[i];
        i++;
    }
    i=n-1,j=m-1;
    while(a1[i]>0&&a2[j]>0&&i>=0&&j>=0)
    {
        ans+=a1[i]*a2[j];
        i--,j--;
    }
    printf("%lld",ans);
    return 0;
}
### 关于优惠券管理系统或API的技术背景 在信息技术领域,优惠券管理系统的实现通常依赖于微服务架构以及RESTful API的设计模式。通过这些技术手段,可以构建灵活且可扩展的应用程序接口(API),用于管理和分发优惠券。 #### 微服务中的控制器设计 在一个典型的微服务项目中,类似于`OpenFeignController`这样的类被用来处理HTTP请求并调用远程服务[^1]。例如,在一个优惠券管理系统中,可能会存在类似的结构来接收前端发送的消息或者参数,并将其传递给后台的服务层进行进一步处理: ```java @RestController public class CouponManagementController { @Autowired private CouponService couponService; @PostMapping("/api/coupon/create") public ResponseEntity<String> createCoupon(@RequestBody CouponRequest request) { boolean result = couponService.create(request); return result ? ResponseEntity.ok("Success") : ResponseEntity.badRequest().body("Failed"); } } ``` 上述代码片段展示了一个简单的创建优惠券功能的API端点定义[^3]。它接受来自客户端的一个JSON对象作为输入数据(`@RequestBody`)并通过注入的服务组件执行具体的业务逻辑操作。 #### 测试与调试环境配置 对于实际部署前的功能验证阶段,则需要设置好相应的测试服务器地址以便开发者能够顺利完成前后端联合调试工作[^2]。比如当涉及到第三方存储桶策略获取时可能就需要访问类似下面这样一个URL路径来进行相关资源权限控制方面的探索研究——即`http://localhost:88/api/thirdparty/oss/policy`。 综上所述,在现代软件开发过程中,“优惠券管理系统”不仅限于单一模块内部事务处理能力提升那么简单;更重要的是如何借助先进的网络通信协议标准(如HTTP)、编程范式转变(面向对象到函数式风格过渡期间所积累的经验教训等等),再加上合理运用容器化技术和自动化运维工具链之后才能真正意义上达到高效稳定运行状态下的商业价值最大化目标!
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值