问题描述
试题编号: 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. 推荐使用国内的豆瓣源安装Python插件

    以前都是用pip安装Python插件的,直到今天 pip的原理其实是从Python的官方源pypi.python.org/pypi下载到本地,然后解包安装 但是有的时候,这个操作会非常慢,国内可以通过 ...

  2. Hbuilder中添加Babel自动编译

    Hbuilder是一个不错的H5开发IDE. Babel是EMCAScript最新标准的编译器,很多ES的最新特性都可以在Babel中尝试. 如果可以有办法在Hbuilder中直接使用ES6,并通过B ...

  3. python常用模块上篇

    python常见模块 分两篇分别介绍下述模块 time模块 random模块 hashlib模块 os模块 sys模块 logging模块 序列号模块 configparser模块 re模块 time ...

  4. Python 之简单线程池创建

    try: from Queue import Queue, Empty except: from queue import Queue, Empty import threading import t ...

  5. Maven 设置Maven源/镜像

    在Eclipse/ InteliJ Idea使用Maven时,企业提供的本地仓库经常有些Jar包下载不下来,所以.配置Maven设置国内镜像对开发人员来说是必不可少的.今天写一篇自己配制的Maven镜 ...

  6. SAXReader简单实例解析HTML

    转载自:http://blog.csdn.net/seayqrain/article/details/5024068# 使用SAXReader需要导入dom4j-full.jar包. dom4j是一个 ...

  7. return flase 作用

    调用return false的时候,他实际上做了三件事   event.preventDefault();     禁止默认行为   event.stopPropagation();   阻止冒泡   ...

  8. 如何运用GitHub来提高生产效率

    这是一篇GitHub的入门级文章,主要针对git的初学者.我们将讨论初学者最关心的一些问题,如:为什么我们要使用GitHub,它的应用有哪些,如何运用它去帮助我们提高工作效率,以及它的基本用法有哪些. ...

  9. Luogu P1541 乌龟棋(NOIP2010TG)

    自己的第一篇博文 祭一下祭一下 题目背景 小明过生日的时候,爸爸送给他一副乌龟棋当作礼物. 题目描述 乌龟棋的棋盘是一行N个格子,每个格子上一个分数(非负整数).棋盘第1格是唯一的起点,第N格是终点, ...

  10. Easy UI下拉列表默认选中(多行)与为文本框赋值

    1.为单行文本框赋值 var data2 = $('#LoadArea').combobox("getData"); if (data2) { $('#id).combobox(' ...