【CCF-CSP】 201412-3 集合竞价 C++


一、题目

在这里插入图片描述

原题目链接

二、解题

1.题目

这是一个股票市场模拟交易程序。它通过读入一行代表操作(买、卖或撤单)的字符串,进行相应的操作并计算出最优解(即所有买卖双方交易的最大数量)以及最终成交价格,最后输出这个最优解和价格。

  1. 输入并存储数据
    在输入数据过程中,程序通过一个 while 循环读入每行操作,并将其存储在一个 NODE 类型的数组 node 中,同时一个序号 index记录了读入数据的个数。对于每个买入或卖出操作,它将对应的价格和数量存储在 node 数组中,同时将其标记为买方或卖方。对于撤单操作,程序将索引为 index
    的数据清除,即将它的价格和数量设为 0。这个循环会一直进行,直到无法读入更多数据为止。
  2. 计算买卖数据
    计算买卖数据部分,程序先对 node 数组按照价格和买卖方向进行排序,将低价和卖单放在前面,高价和买单放在后面。接下来,从第一个不为零的价格记录开始,程序将累加所有卖单的数量并存储在 buy 数组中。然后,程序再从这个价格记录开始,累加所有买单的数量并存储在 sell 数组中。这样,buy[i] 和 sell[i] 分别表示了价格为 node[i].price 时的买单总量和卖单总量。
  3. 寻找最优解和价格并输出
    最后一个部分,寻找最优解和价格。程序遍历 node 数组,对于每个价格,计算出其时的最优解 ans,即买卖双方的最大交易量。取这些最优解中最大的一个,并保存其对应的价格 bestprice。最终,程序输出 bestprice 和对应的最优解 total。

2.代码

dev c++ 5.11

#include<iostream>
#include<algorithm>
using namespace std;
const int N=5010;
struct NODE{
	bool sell;
	double price;
	int  num;
}node[N];
long long buy[N]={0},sell[N]={0};
bool cmp(NODE a, NODE b){
	if(a.price==b.price) return a.sell>b.sell;//价格相等,从sell方到buy方 
	return a.price<b.price;//价格不等,按照价格从小到大 
}
int main(){
	string s;
	int index=1,num_cancal;
	while(cin>>s){
		if(s=="buy"){
			cin>>node[index].price>>node[index].num;
			node[index].sell=false;
		}else if(s=="sell"){
			cin>>node[index].price>>node[index].num;
			node[index].sell=true;
		}else{
			cin>>num_cancal;
			node[num_cancal].price=node[num_cancal].num=0;
		}
		index++;
	}
	sort(node,node+index,cmp);
	int left=1,high=index-1;
	long long ans=0,total=0,sum=0;
	double bestprice=0;
	while(node[left].price==0) left++;
	for(int i=high;i>=left;i--){
		if(!node[i].sell) sum+=node[i].num;
		buy[i]=sum;
	}
	sum=0;
	for(int i=left;i<=high;i++){
		if(node[i].sell) sum+=node[i].num;
		sell[i]=sum;
	}
	for(int i=left;i<=high;i++){
		ans=min(buy[i],sell[i]);
		if(ans>=total){
			total=ans;
			bestprice=node[i].price;
		}
	}
	printf("%.2lf %lld",bestprice,total); 
	
}


3.提交结果

相邻数对

总结

1.解释

  1. sort(node,node+index,cmp);低价和卖单在前,卖单和高价在后
bool cmp(NODE a, NODE b){
	if(a.price==b.price) return a.sell>b.sell;//价格相等,从sell方到buy方 
	return a.price<b.price;//价格不等,按照价格从小到大 
}
  1. printf("%.2lf %lld",bestprice,total);

这是一行C语言代码,将两个变量的值打印到屏幕上。

其中,“%.2lf"指的是将浮点数类型的变量bestprice以保留两位小数的形式输出,”%lld"则是将长整型变量total按十进制整数输出。

在输出时,浮点数和长整型之间会有一个空格分隔。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值