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编号.进行搜索时, ...
随机推荐
- ZXingObjC直接引用第三方工程使用方法
1.下载ZXingObjc压缩包,解压缩. 2.将文件拷贝到项目工程目录下 3.到工程目录中ZXingObjc文件夹中将ZXing的执行文件拖拽到项目中. 4.点击项目targets ——>Bu ...
- SpringBoot图文教程15—项目异常怎么办?「跳转404错误页面」「全局异常捕获」
有天上飞的概念,就要有落地的实现 概念十遍不如代码一遍,朋友,希望你把文中所有的代码案例都敲一遍 先赞后看,养成习惯 SpringBoot 图文教程系列文章目录 SpringBoot图文教程1-Spr ...
- Protocol buffers编写风格指南
原文链接:https://developers.google.com/protocol-buffers/docs/style Style Guide 本文说明了.proto文件的编写风格指南.遵循这些 ...
- EF6.0 下sql语句自动生成的参数类型decimal(18,2)修改
很多时候我们需要对插入到数据库的数据的精度做一个控制,例如sql server下保留6位小数使用numeric(10,6) .而到c#里对应的数据类型就是decimal ,但是使用EF6.0的crea ...
- CSS 文本截断方案
单行截断 .ellipsis { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; } 此方法兼容到ie6过.不过只能单行 ...
- 曹工说mini-dubbo(1)--为了实践动态代理,我写了个简单的rpc框架
相关背景及资源: 之前本来一直在写spring源码解析这块,如下,aop部分刚好写完.以前零散看过一些文章,知道rpc调用基本就是使用动态代理,比如rmi,dubbo,feign调用等.自己也就想着试 ...
- anconda添加镜像源
# anaconda 安装镜像源 *** 在使用安装 conda 安装某些包会出现慢或安装失败问题,最有效方法是修改镜 像源为国内镜像源. 之前都选用清华镜像源,但是2019年 ...
- Codeforces Round #369 (Div. 2)E
ZS and The Birthday Paradox 题目:一年有2^n天,有k个人,他们的生日有冲突的概率是多少?答案用最简分数表示,分子分母对1e6+3取模.1 ≤ n ≤ 10^18, 2 ≤ ...
- PDF顯示插件
1. ie瀏覽器適用<object id="pdf_panel" class="pdf-panel" classid="clsid:CA8A97 ...
- Java-字节输入输出。(新手)
参考手册: BufferedInputStream BufferedOutputStream 实例: import java.io.*; /* * 文件的复制方式 * 1 字节流读写单个字节 * 2 ...