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

解题思路:

这道题一直拿不了满分从0/30/40/50/90,心累

一道模拟题,暴力枚举,算出每个价格下的成交量取大值

我确定的价格的变化范围是卖出的最低价~买进的最高价之间,因为小于卖出的最低价或者大于买进的最高价都会使得成交量变成0,没有什么特别大的意义。

从低价格向上枚举。

注意:

刚开始以为会存在这样的情况:

存在一条删除命令 要删除买进或者卖出的股票

再来一条删除命令 要删除前面的删除命令/相当于前面的删除命令失效了

因为题目描述的不清楚,导致了我这样的幻觉~

去掉这部分代码之后就变成90分了。




源代码:
<span style="font-size:18px;">#include<iostream>
#include<cstdio>
#include<cstring>
#include<cmath>
#include<string>
#include<algorithm>
using namespace std; struct node
{
int flag;//是否删除
int bs;//买进还是卖出还是删除命令,1表示买进,-1表示卖出,0表示删除命令
int price;//股票价格
int number;//股票数量
int index;//处于第几行命令
int del;//要删除第几行的命令
}; node ans[5005]; void init()
{
for(int i=0;i<5005;i++)
{
ans[i].flag=0;//表示不删除该命令
ans[i].del=-1;//-1表示当前命令是b or s
ans[i].bs=0;
}
} int main()
{
char s[15];
int k=1;//命令的位置
int num;
double pri;
int order;
init();
while(scanf("%s",s)!=EOF)
{
if(s[0]=='b')//买进股票
{
scanf("%lf%d",&pri,&num);
ans[k].bs=1;
ans[k].index=k;
ans[k].number=num;
ans[k].price=(int)(pri*100);
k++;
}
else if(s[0]=='s')//卖出股票
{
scanf("%lf%d",&pri,&num);
ans[k].bs=-1;
ans[k].index=k;
ans[k].number=num;
ans[k].price=(int)(pri*100);
k++;
}
else if(s[0]=='c')//删除命令
{
scanf("%d",&order);
ans[k].del=order;
ans[k].index=k;
int temp=order;
ans[temp].flag=1;
k++;
}
}
int max_pri=0;
int min_pri=0x3f3f3f3f;
for(int i=1;i<k;i++)
{
if(ans[i].bs==1&&ans[i].flag==0)
{
if(ans[i].price>max_pri)
max_pri=ans[i].price;
}
}
for(int i=1;i<k;i++)
{
if(ans[i].bs==-1&&ans[i].flag==0)
{
if(ans[i].price<min_pri)
min_pri=ans[i].price;
}
}
long long ans_num=0;
int ans_pri;
for(int i=min_pri;i<=max_pri;i++)
{
long long pb=0;
long long ps=0;
for(int j=1;j<k;j++)
{
if(ans[j].bs==1&&ans[j].flag==0&&ans[j].price>=i)//买
{
pb+=ans[j].number;
}
else if(ans[j].bs==-1&&ans[j].flag==0&&ans[j].price<=i)//卖
{
ps+=ans[j].number;
}
long long temp=min(pb,ps);
if(temp>=ans_num)
{
ans_pri=i;
ans_num=temp;
}
}
}
double res_pri=(ans_pri*1.0)/100;
printf("%.2lf %lld\n",res_pri,ans_num);
return 0;
}</span>


CCF-201412-3-集合竞价的更多相关文章

  1. CCF CSP 201412-3 集合竞价

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF CSP 201412-3 集合竞价 问题描述 某股票交易所请你编写一个程序,根据开盘前客户提交的订单来确 ...

  2. ccf集合竞价

    我不懂为什么是错误.然后零分.贴出测试. 然后即使注释掉while循环中的break部分,也是如此. #include<iostream> #include<iomanip> ...

  3. CCF 集合竞价

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

  4. CCF计算机职业资格认证考试题解

    CCF计算机职业资格认证考试题解系列文章为meelo原创,请务必以链接形式注明本文地址 CCF计算机职业资格认证考试题解 CCF计算机软件能力认证(简称CCF CSP认证)是CCF计算机职业资格认证系 ...

  5. CCF认证历年试题

    CCF认证历年试题 不加索引整理会死星人orz 第一题: CCF201712-1 最小差值(100分) CCF201709-1 打酱油(100分) CCF201703-1 分蛋糕(100分) CCF2 ...

  6. CCF考试

    第八次CCF考试记录 代码还不知道对不对,过两天出成绩. 成绩出来了,310分. 100+100+100+10+0: 考试13:27开始,17:30结束,提交第4题后不再答题,只是检查前四题的代码 第 ...

  7. CCF关于NOIP2014复赛报名的通知

    CCF关于NOIP2014复赛报名的通知   CCF NOIP2014复赛全部实行网上注册.报名.未通过网上报名的选手将不具备参赛和申诉资格. 系统注册须知: NOIP2014复赛注册时间:2014年 ...

  8. [CCF] Z字形扫描

    CCF Z字形扫描 感觉和LeetCode中的ZigZag还是有一些不一样的. 题目描述 在图像编码的算法中,需要将一个给定的方形矩阵进行Z字形扫描(Zigzag Scan).给定一个n×n的矩阵,Z ...

  9. [CCF] ISBN号码检测

    CCF ISBN号码检测 题目概述 每一本正式出版的图书都有一个ISBN号码与之对应,ISBN码包括9位数字.1位识别码和3位分隔符,其规定格式如"x-xxx-xxxxx-x",其 ...

  10. CCF NOI系列活动

    NOI-全国青少年信息学奥林匹克竞赛全国青少年信息学奥林匹克竞赛(NOI)是国内信息学领域内面向中学生的最高水平的大赛,每省派经选拔产生的选手(其中一名是女选手)参加,NOI每年在不同的省市举行. N ...

随机推荐

  1. PHP二分查找算法

    思路:递归算法.在一个已经排好序的数组中查找某一个数值,每一次都先跟数组的中间元素进行比较,若相等则返回中间元素的位置,若小于中间元素,则在数组中小于中间元素的部分查找,若大于中间元素,则在数组中大于 ...

  2. LeetCode 62. Unique Paths(所有不同的路径)

    A robot is located at the top-left corner of a m x n grid (marked 'Start' in the diagram below). The ...

  3. 03-从零玩转JavaWeb-创建类与对象

    创建类创建对象 一.什么是成员变量 对象的一些状态特征使用成员变量表示   二.行为什么什么表示 对象的 行为 使用 方法 表示   三.如何创建对象 class 类名{0 ~ N个成员变量0 ~ N ...

  4. [Bayesian] “我是bayesian我怕谁”系列 - Latent Variables

    下一章有意讲讲EM和变分推断的内容. EM和变分推断的内容能Google到很多,虽然质量乘次不齐,但本文也无意再赘述那么些个细节. 此处记录一些核心思想,帮助菜鸡形成整体上的认识.不过,变分推断也不是 ...

  5. iOS布局

    1.Masonry 创建constraint来定义布局的方式: 1.1. mas_makeConstraints : 你可以使用局部变量后者属性来保存以便下次应用它 1.2. mas_updateCo ...

  6. Windows环境下多线程编程原理与应用读书笔记(8)————信号量及其应用

    <一>线程间同步原因 线程间竞争共享资源: 线程间为完成某个任务而协作: 通过互斥量可以实现线程间由于竞争所需要的同步,通过事件可以实现线程间由于协作所需要的同步. 信号量很好地将互斥量和 ...

  7. Coins(多重背包+二进制优化)

    Problem Description Whuacmers use coins.They have coins of value A1,A2,A3...An Silverland dollar. On ...

  8. 学习笔记TF060:图像语音结合,看图说话

    斯坦福大学人工智能实验室李飞飞教授,实现人工智能3要素:语法(syntax).语义(semantics).推理(inference).语言.视觉.通过语法(语言语法解析.视觉三维结构解析)和语义(语言 ...

  9. 密码学那些事———SHA-512及其C++实现

    SHA-512及其C++实现 转载请注明出处 一.引言 相信大家对于哈希压缩加密算法应该不陌生,在我们用微信或者支付宝接口的时候经常会遇到用这类算法加密,以验证数据的完整性.可以说这类算法无处不在,那 ...

  10. 再学习之MyBatis

    一.框架基本介绍 1.概念 支持普通SQL查询.存储过程和高级映射,简化和实现了Java 数据持久化层的的开源框架,主要流行的原因在于他的简单性和易使用性. 2.特点 持久层 .ORM(对象关系映射) ...