试题编号: 201412-3
试题名称: 集合竞价
时间限制: 1.0s
内存限制: 256.0MB
问题描述:
问题描述
某股票交易所请你编写一个程序,根据开盘前客户提交的订单来确定某特定股票的开盘价和开盘成交量。
  该程序的输入由很多行构成,每一行为一条记录,记录可能有以下几种:
  1. buy p s 表示一个购买股票的买单,每手出价为p,购买股数为s。
  2. sell p s 表示一个出售股票的卖单,每手出价为p,出售股数为s。
  3. cancel i表示撤销第i行的记录。
  如果开盘价为p0,则系统可以将所有出价至少为p0的买单和所有出价至多为p0的卖单进行匹配。因此,此时的开盘成交量为出价至少为p0的买单的总股数和所有出价至多为p0的卖单的总股数之间的较小值。
  你的程序需要确定一个开盘价,使得开盘成交量尽可能地大。如果有多个符合条件的开盘价,你的程序应当输出最高的那一个。
输入格式
输入数据有任意多行,每一行是一条记录。保证输入合法。股数为不超过108的正整数,出价为精确到恰好小数点后两位的正实数,且不超过10000.00。
输出格式
你需要输出一行,包含两个数,以一个空格分隔。第一个数是开盘价,第二个是此开盘价下的成交量。开盘价需要精确到小数点后恰好两位。
样例输入
buy 9.25 100
buy 8.88 175
sell 9.00 1000
buy 9.00 400
sell 8.92 400
cancel 1
buy 100.00 50
样例输出
9.00 450
评测用例规模与约定
对于100%的数据,输入的行数不超过5000。

问题链接:CCF201412试题。

问题描述:(参见上文)。

问题分析:这是一个竞价匹配的问题。数据可以存储在结构数组中,但未必是好的方案。使用两个优先队列,一个用于存储购入订单,按价格从大到小排列;另外一个用于存储卖出订单,按价格从小到大排列;然后进行价格的匹配处理。

程序说明:(略)。

提交后得100分的C++语言程序如下:

/* CCF201412-3 集合竞价 */#include <iostream>
#include <queue>
#include <cstring>
#include <cstdio>using namespace std;const int N = 5000;struct trading {int orderno;char t;float price;long long quantity;bool operator < (const trading& n) const {if(t == 's')return price > n.price;else // t == 'b'return price < n.price;}
};bool cancelflag[N+1];int main()
{trading t;priority_queue<trading> sell, buy;string strading;// 变量初始化memset(cancelflag, false, sizeof(cancelflag));// 输入数据int no = 0, tno;while(cin >> strading) {if(strading[0] == 'c') {// 设置交易号no++;// 输入取消的交易号cin >> tno;// 设置取消标志cancelflag[tno] = true;} else if(strading[0] == 'b' || strading[0] == 's') {// 设置交易号t.orderno = ++no;// 输入交易价格和数量cin >> t.price >> t.quantity;// 将交易分别放入买入和卖出的优先队列if(strading[0] == 'b') {t.t = strading[0];buy.push(t);} else {    // t.trading[0] == 's't.t = strading[0];sell.push(t);}} elsebreak;}// 集合竞价处理t.price = 0;t.quantity = 0;trading b, s;for(;;) {// 清除被取消的订单(同时将队头放在b和s中)while(!buy.empty()) {b = buy.top();if(cancelflag[b.orderno])buy.pop();elsebreak;}while(!sell.empty()) {s = sell.top();if(cancelflag[s.orderno])sell.pop();elsebreak;}// 买卖队列只要有一个为空,则处理结束if(buy.empty() || sell.empty())break;// 集合竞价处理if(b.price >= s.price) {t.quantity += min(b.quantity, s.quantity);t.price = b.price;if(b.quantity == s.quantity) {buy.pop();sell.pop();} else if(b.quantity > s.quantity) {b.quantity -= s.quantity;buy.pop();buy.push(b);sell.pop();} else {    // b.quantity < s.quantitybuy.pop();s.quantity -= b.quantity;sell.pop();sell.push(s);}} elsebreak;}// 输出结果printf("%.2f", t.price);cout << " " << t.quantity << endl;return 0;
}/*
测试样例:sell 8.88 100
sell 8.88 175
sell 9.00 400
buy 8.88 400
cancel 1
sell 100.00 50
8.88 175buy 9.25 100
buy 8.88 175
buy 9.00 400
sell 8.88 400
cancel 1
buy 100.00 50
9.00 400buy 9.25 100
buy 8.88 175
buy 9.00 400
sell 8.79 1501
cancel 1
cancel 2
9.00 400buy 9.25 110
buy 8.88 300
buy 18.88 200
sell 8.88 201
sell 9.25 100
9.25 301
*/

CCF201412-3 集合竞价(100分)相关推荐

  1. CCF201412-2 Z字形扫描(解法二)(100分)

    试题编号: 201412-2 试题名称: Z字形扫描 时间限制: 2.0s 内存限制: 256.0MB 问题描述: 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag ...

  2. CCF201412-2 Z字形扫描(解法二)(100分)【废除!!!】

    试题编号: 201412-2 试题名称: Z字形扫描 时间限制: 2.0s 内存限制: 256.0MB 问题描述: 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag ...

  3. CCF201412-4 最优灌溉(解法二)(100分)【废除!!!】

    试题编号: 201412-4 试题名称: 最优灌溉 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 雷雷承包了很多片麦田,为了灌溉这些麦田,雷雷在第一个麦田挖了一口很深的水井, ...

  4. CCF201412-4 最优灌溉(100分)

    试题编号: 201412-4 试题名称: 最优灌溉 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 雷雷承包了很多片麦田,为了灌溉这些麦田,雷雷在第一个麦田挖了一口很深的水井, ...

  5. CCF201412-2 Z字形扫描(100分)

    试题编号: 201412-2 试题名称: Z字形扫描 时间限制: 2.0s 内存限制: 256.0MB 问题描述: 问题描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag ...

  6. CCF201412-1 门禁系统(100分)

    试题编号: 201412-1 试题名称: 门禁系统 时间限制: 1.0s 内存限制: 256.0MB 问题描述: 问题描述 涛涛最近要负责图书馆的管理工作,需要记录下每天读者的到访情况.每位读者有一个 ...

  7. CCF-CSP认证历年真题解(100分)

    转载: 链接出自:https://blog.csdn.net/tigerisland45/article/details/54755895 CCF-CSP认证历年真题解–python语言 CCF-CS ...

  8. CCF 201412-3 集合竞价 90分代码 C++

    问题描述 某股票交易所请你编写一个程序,根据开盘前客户提交的订单来确定某特定股票的开盘价和开盘成交量. 该程序的输入由很多行构成,每一行为一条记录,记录可能有以下几种: 1. buy p s 表示一个 ...

  9. 四川高中计算机学校图片,四川2021年100分能上计算机学校吗

    四川100分能上计算机学校吗?从计算机学校方面所进行分析地话,中专计算机学校所对其学生的各方面要求是比较容易被进行满足的,而从学生所考的100分成绩来说的话,成绩是比较地低的,如果想要报读计算机学校的 ...

最新文章

  1. JW Player使用简介
  2. windows powershell实战指南_【安全研究】powershell在主机中是否存在安全隐患?
  3. Oracle的一点注意点
  4. python布尔系列_python数据分析类库系列-Numpy之布尔型索引
  5. Pycharm SSH 容器中的python环境
  6. python echarts mysql python_Django中从mysql数据库中获取数据传到echarts方式
  7. 计算机管理员无法创建密码,找到电脑管理员的密码
  8. java的基本数据类型有八种
  9. 6. PHP 正则表达式
  10. CSDN markdown 数学公式指导手册
  11. 发家致富:爬取双色球信息并统计
  12. 代数余子式与伴随矩阵
  13. labelImg打开闪退怎么解决
  14. surreal number应对不平等博弈
  15. CentOS 8.1安装MySQL 8.0详解
  16. sec^3 不定积分
  17. 账号已被停用,请咨询系统管理员
  18. 如何写好方案规划设计文档,这里有一份实践清单
  19. P1618 三连击(升级版)
  20. 敏感关键词 词库_【店铺技能】1688会员新手如何去优化关键词!

热门文章

  1. 600个开源iOS应用库
  2. 如何在游戏机制中使用AI/剧情脚本----基于LUA
  3. .net中三种Timer使用总结
  4. sass-loader高版本的坑
  5. linux界面三个图标,配置Ubuntu Enlightenment桌面环境之三:桌面图标和根菜单_Linux学院_风信网...
  6. 塞尔达盾反机器人_《塞尔达传说:荒野之息》新手盾反技巧详解攻略
  7. java成员访问修饰符,如何使用java反射查找成员的访问修饰符
  8. Navicat加载缓慢
  9. java框架注入是创建对象吗_spring之IOC容器创建对象
  10. oracle sequence 应用,oracle应用之使用sequence批量写数据