PTA数据结构与算法题目集(中文) 7-39魔法优惠券 (25 分)
PTA数据结构与算法题目集(中文) 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]之间,所有的数据大小不超过230,数字间以空格分隔。
输出格式:
输出可以得到的最大回报。
输入样例:
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 分)的更多相关文章
- PTA数据结构与算法题目集(中文) 7-37 模拟EXCEL排序 (25 分)
PTA数据结构与算法题目集(中文) 7-37 模拟EXCEL排序 (25 分) 7-37 模拟EXCEL排序 (25 分) Excel可以对一组纪录按任意指定列排序.现请编写程序实现类似功能. ...
- PTA数据结构与算法题目集(中文) 7-35 城市间紧急救援 (25 分)
PTA数据结构与算法题目集(中文) 7-35 城市间紧急救援 (25 分) 作为一个城市的应急救援队伍的负责人,你有一张特殊的全国地图.在地图上显示有多个分散的城市和一些连接城市的快速道路.每个城市 ...
- PTA数据结构与算法题目集(中文) 7-29
PTA数据结构与算法题目集(中文) 7-29 7-29 修理牧场 (25 分) 农夫要修理牧场的一段栅栏,他测量了栅栏,发现需要N块木头,每块木头长度为整数Li个长度单位,于是他购买了一条 ...
- PTA数据结构与算法题目集(中文) 7-28
PTA数据结构与算法题目集(中文) 7-28 7-28 搜索树判断 (25 分) 对于二叉搜索树,我们规定任一结点的左子树仅包含严格小于该结点的键值,而其右子树包含大于或等于该结点的键值.如果我 ...
- PTA数据结构与算法题目集(中文) 7-25
PTA数据结构与算法题目集(中文) 7-25 7-25 朋友圈 (25 分) 某学校有N个学生,形成M个俱乐部.每个俱乐部里的学生有着一定相似的兴趣爱好,形成一个朋友圈.一个学生可以同时属于若干 ...
- PTA数据结构与算法题目集(中文) 7-24
PTA数据结构与算法题目集(中文) 7-24 7-24 树种统计 (25 分) 随着卫星成像技术的应用,自然资源研究机构可以识别每一棵树的种类.请编写程序帮助研究人员统计每种树的数量,计算每种树 ...
- PTA数据结构与算法题目集(中文) 7-23
PTA数据结构与算法题目集(中文) 7-23 7-23 还原二叉树 (25 分) 给定一棵二叉树的先序遍历序列和中序遍历序列,要求计算该二叉树的高度. 输入格式: 输入首先给出正整数N(≤50) ...
- PTA数据结构与算法题目集(中文) 7-20
PTA数据结构与算法题目集(中文) 7-20 7-20 表达式转换 (25 分) 算术表达式有前缀表示法.中缀表示法和后缀表示法等形式.日常使用的算术表达式是采用中缀表示法,即二元运算符位于两个 ...
- PTA数据结构与算法题目集(中文) 7-9
PTA数据结构与算法题目集(中文) 7-9 7-9 旅游规划 (25 分) 有了一张自驾旅游路线图,你会知道城市间的高速公路长度.以及该公路要收取的过路费.现在需要你写一个程序,帮助前来咨询的游 ...
- PTA数据结构与算法题目集(中文) 7-6
PTA数据结构与算法题目集(中文) 7-6 7-6 列出连通集 (25 分) 给定一个有N个顶点和E条边的无向图,请用DFS和BFS分别列出其所有的连通集.假设顶点从0到N−1编号.进行搜索时, ...
随机推荐
- JVM04——七个GC垃圾收集器,一个都不能少
了解了JVM内存区域与垃圾回收算法,今天将为各位带来关于垃圾收集器的知识.关注我的公众号「Java面典」了解更多 Java 相关知识点. Java 堆内存被划分为新生代和老年代两部分,因此 JVM 通 ...
- 吃透这份pdf,面试阿里、腾讯、百度等一线大厂,顺利拿下心仪offer!
前言 最近一位年前裸辞的朋友来找我诉苦,说因为疫情原因现在都在家吃老本.本想着年后就来找工作的,但是现在这个情况也不好找,而且很多公司也随着这次疫情面临着资金紧缺导致裁员严重的甚至倒闭,导致很多人失业 ...
- failed to open directory
解决方法: 解决方案的路径不要包含中文!
- Android微信逆向--实现发朋友圈动态
0x0 前言 最近一直在研究Windows逆向的东西,想着快要把Android给遗忘了.所以就想利用工作之余来研究Android相关的技术,来保持对Android热情.调用微信代码来发送朋友圈动态一直 ...
- keep-alive 必须 页面有name 要不缓存不住数据
keep-alive 必须 页面有name 要不缓存不住数据
- java第一次上机练习作业
1.已知a,b均是整型变量,写出将a,b两个变量中的值互换的程序.(知识点:变量和 运算符综合应用) int a = 5, b = 10; int temp; temp = a; a = b; b = ...
- AVR单片机教程——走向高层
本文隶属于AVR单片机教程系列. 在系列教程的最后一篇中,我将向你推荐3个可以深造的方向:RTOS.C++.事件驱动.掌握这些技术可以帮助你更快.更好地开发更大的项目. 本文涉及到许多概念性的内容 ...
- hive学习_01
1.构建在Hadoop之上的数据仓库(数据计算使用MR,数据存储使用HDFS) 2.Hive定义了一种类SQL查询语言----HQL 3.通常用于进行离线数据处理(非实时) 4.一个ETL工具 5.可 ...
- MySQL语句-关于表单的操作总结(新手)
MySQl表的操作: 主键的添加: CREATE TABLE 表名(列名称 数据类型--id INT PRIMARY KEY AUTO_INCREMENT,列名称2 数据类型,············ ...
- 74. pNextID、pNextVal、pNID的区别
pNextID是平台调用单个新增组件的时候调用的: pNextVal是平台批量新增的时候调用: pNID应该是自己写的 :