博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
CCF - 201412-3 - 集合竞价
阅读量:4550 次
发布时间:2019-06-08

本文共 3204 字,大约阅读时间需要 10 分钟。

问题描述

试题编号: 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。

思路

使用两个优先队列,一个用于存储购入订单,按价格从大到小排列;另外一个用于存储卖出订单,按价格从小到大排列;然后进行价格的匹配处理。

代码

#include
#include
#include
#include
using namespace std;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 if(t == 'b') return price < n.price; }};bool cancelflag[5001];int main(){ trading t; priority_queue
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.t = strading[0]; sell.push(t); } } else break; } // 集合竞价处理 t.price = 0; t.quantity = 0; trading b, s; for(;;) { // 清除被取消的订单(同时将队头放在b和s中) while(!buy.empty()) { b = buy.top(); if(cancelflag[b.orderno]) buy.pop(); else break; } while(!sell.empty()) { s = sell.top(); if(cancelflag[s.orderno]) sell.pop(); else break; } // 买卖队列只要有一个为空,则处理结束 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 { buy.pop(); s.quantity -= b.quantity; sell.pop(); sell.push(s); } } else break; } // 输出结果 printf("%.2f", t.price); cout << " " << t.quantity << endl; return 0;}

 

转载于:https://www.cnblogs.com/5211314jackrose/p/7530660.html

你可能感兴趣的文章
离线下载解决Nuget程序包及其依赖包的方法
查看>>
react中的refs
查看>>
使用cvCanny方法边缘检测出现的错误
查看>>
redhat6.5安装oracle 11g
查看>>
Using View and Data API with Meteor
查看>>
python cmd模块练习
查看>>
前端知识点
查看>>
Java的访问权限
查看>>
HTML5 1.5 表格元素
查看>>
SMT(SF)
查看>>
Android系列--DOM、SAX、Pull解析XML
查看>>
关于64位 MS SQL 导入导出 Oracle 引发 ORA-06413 的解决方法
查看>>
java.io.UnsupportedEncodingException
查看>>
浅析手机抓包方法实践(zt)
查看>>
记一次MySQl 安装1067错误
查看>>
DirectSound的应用
查看>>
MessageDigest简单介绍
查看>>
python基础学习笔记(十一)
查看>>
HTMl5的sessionStorage和localStorage(转)
查看>>
网络是怎样连接的-路由器的包转发操作(上)
查看>>