PTA数据结构与算法题目集(中文)  7-39魔法优惠券 (25 分)

7-39 魔法优惠券 (25 分)
 

在火星上有个魔法商店,提供魔法优惠券。每个优惠劵上印有一个整数面值K,表示若你在购买某商品时使用这张优惠劵,可以得到K倍该商品价值的回报!该商店还免费赠送一些有价值的商品,但是如果你在领取免费赠品的时候使用面值为正的优惠劵,则必须倒贴给商店K倍该商品价值的金额…… 但是不要紧,还有面值为负的优惠劵可以用!(真是神奇的火星)

例如,给定一组优惠劵,面值分别为1、2、4、-1;对应一组商品,价值为火星币M$7、6、-2、-3,其中负的价值表示该商品是免费赠品。我们可以将优惠劵3用在商品1上,得到M$28的回报;优惠劵2用在商品2上,得到M$12的回报;优惠劵4用在商品4上,得到M$3的回报。但是如果一不小心把优惠劵3用在商品4上,你必须倒贴给商店M$12。同样,当你一不小心把优惠劵4用在商品1上,你必须倒贴给商店M$7。

规定每张优惠券和每件商品都只能最多被使用一次,求你可以得到的最大回报。

输入格式:

输入有两行。第一行首先给出优惠劵的个数N,随后给出N个优惠劵的整数面值。第二行首先给出商品的个数M,随后给出M个商品的整数价值。N和M在[1, 1]之间,所有的数据大小不超过2​30​​,数字间以空格分隔。

输出格式:

输出可以得到的最大回报。

输入样例:

4 1 2 4 -1
4 7 6 -2 -3

输出样例:

43
题目分析:用优先队列来每次找出最好的情况,看了大佬的做法,其实只需要排序就好了,每次找出符号相同的最好情况 但这题我最后一个测试题无法通过
 #define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<string.h>
#include<malloc.h>
#define INIFITY -65535
typedef struct HeapStruct* H;
struct HeapStruct
{
int Heap[];
int Size;
}MaxHeap1,MaxHeap2; int Delete(H MaxHeap)
{
int Max = MaxHeap->Heap[];
int Tmp = MaxHeap->Heap[MaxHeap->Size--];
int Parent, Child;
for (Parent = ; Parent * <= MaxHeap->Size; Parent = Child)
{
Child = Parent * ;
if (Child != MaxHeap->Size && MaxHeap->Heap[Child] < MaxHeap->Heap[Child + ])
Child++;
if (Tmp >= MaxHeap->Heap[Child])break;
else
MaxHeap->Heap[Parent] = MaxHeap->Heap[Child];
}
MaxHeap->Heap[Parent] = Tmp;
return Max;
}
int DeleteM(H MinHeap)
{
int Min = MinHeap->Heap[];
int Tmp = MinHeap->Heap[MinHeap->Size--];
int Parent, Child;
for (Parent = ; Parent * <= MinHeap->Size; Parent = Child)
{
Child = Parent * ;
if (Child != MinHeap->Size && MinHeap->Heap[Child]>MinHeap->Heap[Child + ])
Child++;
if (Tmp <= MinHeap->Heap[Child])break;
else
MinHeap->Heap[Parent] = MinHeap->Heap[Child];
}
MinHeap->Heap[Parent] = Tmp;
return Min;
} void PrecDown(H MaxHeap, int i)
{
int Parent, Child;
int Tmp = MaxHeap->Heap[i];
for (Parent = i; Parent * <= MaxHeap->Size; Parent = Child)
{
Child = Parent * ;
if (Child != MaxHeap->Size && MaxHeap->Heap[Child] < MaxHeap->Heap[Child + ])
Child++;
if (Tmp >= MaxHeap->Heap[Child])break;
else
MaxHeap->Heap[Parent] = MaxHeap->Heap[Child];
}
MaxHeap->Heap[Parent] = Tmp;
}
void BuildHeap(H MaxHeap)
{
for (int i = MaxHeap->Size / ; i; i /= )
PrecDown(MaxHeap, i);
}
void PrecDownM(H MinHeap, int i)
{
int Parent, Child;
int Tmp = MinHeap->Heap[i];
for (Parent = i; Parent * <= MinHeap->Size; Parent = Child)
{
Child = Parent * ;
if (Child != MinHeap->Size && MinHeap->Heap[Child] > MinHeap->Heap[Child + ])
Child++;
if (Tmp <= MinHeap->Heap[Child])break;
else
MinHeap->Heap[Parent] = MinHeap->Heap[Child];
}
MinHeap->Heap[Parent] = Tmp;
}
void BuildHeapM(H MinHeap)
{
for (int i = MinHeap->Size / ; i; i /= )
PrecDownM(MinHeap, i);
}
int main()
{
MaxHeap1.Heap[] = MaxHeap2.Heap[] = INIFITY;
int N, M;
int num,sum;
scanf("%d", &N);
MaxHeap1.Size = N;
for (int i = ; i <=MaxHeap1.Size; i++)
{
scanf("%d", &num);
MaxHeap1.Heap[i] = num;
}
scanf("%d", &M);
MaxHeap2.Size = M;
for (int i = ; i <=MaxHeap2.Size; i++)
{
scanf("%d", &num);
MaxHeap2.Heap[i] = num;
}
BuildHeap(&MaxHeap1);
BuildHeap(&MaxHeap2);
sum = ;
int num1, num2;
int t = N > M ? M : N;
while (MaxHeap1.Size!=&&MaxHeap2.Size!=)
{
if (MaxHeap1.Heap[] > && MaxHeap2.Heap[] > )
{
num1 = Delete(&MaxHeap1);
num2 = Delete(&MaxHeap2);
sum += num1 * num2;
}
else
break;
}
BuildHeapM(&MaxHeap1);
BuildHeapM(&MaxHeap2);
while (MaxHeap1.Size!=&&MaxHeap2.Size!=)
{
if (MaxHeap1.Heap[] < && MaxHeap2.Heap[] < )
{
num1 = DeleteM(&MaxHeap1);
num2 = DeleteM(&MaxHeap2);
sum += num1 * num2;
}
else
break;
}
printf("%d", sum);
}

PTA数据结构与算法题目集(中文) 7-39魔法优惠券 (25 分)的更多相关文章

  1. PTA数据结构与算法题目集(中文) 7-37 模拟EXCEL排序 (25 分)

    PTA数据结构与算法题目集(中文)  7-37 模拟EXCEL排序 (25 分) 7-37 模拟EXCEL排序 (25 分)   Excel可以对一组纪录按任意指定列排序.现请编写程序实现类似功能. ...

  2. PTA数据结构与算法题目集(中文) 7-35 城市间紧急救援 (25 分)

    PTA数据结构与算法题目集(中文)  7-35 城市间紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市 ...

  3. PTA数据结构与算法题目集(中文) 7-29

    PTA数据结构与算法题目集(中文)  7-29 7-29 修理牧场 (25 分)   农夫要修理牧场的一段栅栏,他测量了栅栏,发现需要N块木头,每块木头长度为整数L​i​​个长度单位,于是他购买了一条 ...

  4. PTA数据结构与算法题目集(中文) 7-28

    PTA数据结构与算法题目集(中文)  7-28 7-28 搜索树判断 (25 分)   对于二叉搜索树,我们规定任一结点的左子树仅包含严格小于该结点的键值,而其右子树包含大于或等于该结点的键值.如果我 ...

  5. PTA数据结构与算法题目集(中文) 7-25

    PTA数据结构与算法题目集(中文)  7-25 7-25 朋友圈 (25 分)   某学校有N个学生,形成M个俱乐部.每个俱乐部里的学生有着一定相似的兴趣爱好,形成一个朋友圈.一个学生可以同时属于若干 ...

  6. PTA数据结构与算法题目集(中文) 7-24

    PTA数据结构与算法题目集(中文)  7-24 7-24 树种统计 (25 分)   随着卫星成像技术的应用,自然资源研究机构可以识别每一棵树的种类.请编写程序帮助研究人员统计每种树的数量,计算每种树 ...

  7. PTA数据结构与算法题目集(中文) 7-23

    PTA数据结构与算法题目集(中文)  7-23 7-23 还原二叉树 (25 分)   给定一棵二叉树的先序遍历序列和中序遍历序列,要求计算该二叉树的高度. 输入格式: 输入首先给出正整数N(≤50) ...

  8. PTA数据结构与算法题目集(中文) 7-20

    PTA数据结构与算法题目集(中文)  7-20 7-20 表达式转换 (25 分)   算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.日常使用的算术表达式是采用中缀表示法,即二元运算符位于两个 ...

  9. PTA数据结构与算法题目集(中文) 7-9

    PTA数据结构与算法题目集(中文)  7-9 7-9 旅游规划 (25 分)   有了一张自驾旅游路线图,你会知道城市间的高速公路长度.以及该公路要收取的过路费.现在需要你写一个程序,帮助前来咨询的游 ...

  10. PTA数据结构与算法题目集(中文) 7-6

    PTA数据结构与算法题目集(中文)  7-6 7-6 列出连通集 (25 分)   给定一个有N个顶点和E条边的无向图,请用DFS和BFS分别列出其所有的连通集.假设顶点从0到N−1编号.进行搜索时, ...

随机推荐

  1. php获取当前周的第一天与最后一天

    1 2 3 4 5 6 7 8 9 10 // 当前日期   $sdefaultDate = date("Y-m-d");   // $first =1 表示每周星期一为开始日期  ...

  2. plsql乱码问题

    1,问题:在plsql 中执行sql语句,查询结果带有中文,出现乱码,即" ??? ":如下: 2,解决: 1)输入sql语句 select * from V$NLS_PARAME ...

  3. 面试总被问分布式ID怎么办? 滴滴(Tinyid)甩给他

    整理了一些Java方面的架构.面试资料(微服务.集群.分布式.中间件等),有需要的小伙伴可以关注公众号[程序员内点事],无套路自行领取 一口气说出 9种 分布式ID生成方式,面试官有点懵了 面试总被问 ...

  4. docker学习之路

    环境 : ubuntu 16.4 下载docker 首先使用命令行下载 docker wget -qO- https://get.docker.com/ | sh 启动 下载完成之后进行一个启动,但是 ...

  5. 鸟哥的Linux私房菜基础学习篇(第三版)——阅读笔记(二)

    第一章 Linux是什么 1.Linux是什么 一套操作系统 早期的Linux是针对386开发的 具有可移植性 2.Unix及Linux的发展史 1973年,Unix诞生,Ritchie等人以C语言写 ...

  6. Intel优化Gen7驱动代码 Geekbench 5性能猛增

    Linux下缺少大量开发.支持是会导致各种奇葩的错误的,Intel日前就提交了一个代码修复,22nm Ivybridge及Haswell处理器的GeekBench 5的性能就提升了330%. 3.3倍 ...

  7. webpack学习(一):webpack的安装和命令行

    本教程可以学习到如下内容: 1.webpack的安装 2.利用webpack命令打包js文件 3.如何在js文件里面引用css并将css文件在页面里面生效 4.学习webpack相关的高级的一些参数, ...

  8. SSM整合搭建(二)

    本页来衔接上一页继续来搭建SSM,再提一下大家如果不详细可以再去看视频哦,B站就有 之后我们来配置SpringMVC的配置文件,主要是配置跳转的逻辑 先扫描所有的业务逻辑组件 我们要用SpringMV ...

  9. Eclipse新建项目介绍

    最近在用Eclipse,对于一个新手来说,新建项目时出现五花八门的名字,该选择哪个进行创建呢?今天小编抱着学习的态度,顺便整理分享给大家. 选择File->New->Project...  ...

  10. 新手版超详细LoadRunner12完整安装+汉化过程

      01下载 首先从百度网盘获取到这几个文件(网盘地址会附在文末,过期请联系): 我安装的是社区版+中文汉化过的,使用我只下载了第一个和第三个文件,下面我将讲一下如何安装. 02安装社区版 1.选择“ ...