购书 (1000x~8)

文章介绍了一个书店的促销策略,利用C++编程实现,给定购买书籍的单价,目标是找到最优分组方式以获得最少费用。程序通过输入书价并进行排序,找出每3本书中价格最低的一本免单,从而计算总花费。
摘要由CSDN通过智能技术生成

书店稿促销优惠活动:“卖 3 本免费 1 本”。即如果你买 3 本书,价格最便宜的那本书就不收钱。如果买很多书, 不同分组优惠的价格可能不同。比如,买 7 本书,价格分别是:10,3,2,4,6,4,9。 如果分组是: (10,3,2),(4,6,4)和(9),第一组免费价格 2,第二组免费价格 4,第三组不能免费。

现在,你买了 N 本书,请恰当分组(每组 1 本到 3 本),使得花费最少?

#include<bits/stdc++.h>
using namespace std;
int ss(int x,int y)
{
    return 0;
}
int n,a[100001],s=0;
int main()
{
    cin>>n;
    for(int i=1;i<=n;i++)
    {
        cin>>a[i];
    }    
    sort(a+1,a+1+n,ss);   
    for(int i=1;i<=n;i++)
        if(i%3!=0) s+=a[i];
    cout<<s;
    return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值