题目描述
二哥需要一个能根据交易记录和股票价格记录统计出先进收益的程序。
现金收益包括两部分,一部分是卖出收入,一部分是每次交易需要支出的费用。卖出收入就是卖出股票获得的总收入减去买入的总支出。股票的价格是按每股的价格给出的,而交易的最小单位是“一手”,每手是100股。每次买入的费用如下所述:
佣金,收取交易额的0.2%,但最低的收取标准是5元。比如买入总金额为1000元的股票,实际佣金是2元,但不超过5元,所以按5元收取。
过户费,每一千股收取1元。
通讯费,由于二哥在上海,每次只收取本地交易费用1元。
每次卖出的费用标准与买入一致,但还要加收证券印花税(交易额的0.1%)。
另外,二哥是个专一的人,他只对一支股票感兴趣。
输入格式
输入分为两部分,第一部分是二哥的交易记录,第二部分是股票价格记录。
交易记录的第一行是一个正整数m,表示共有m个交易动作。每个交易动作占一行,包括三个正整数t, a和d, d = 1时,表示在时间t买入该股票a手,当d = 2时,表示在时间t卖出该股票a手。记录信息保证有意义;d不会取其他值。
股票价格记录的第一行是一个正整数n,表示共有n次价格变动。每次价格变动占一行,包括两个正整数t和v,表示在时间t该股票的价格变为v元每股。价格变动过程是按时间顺序给出的,第一次价格变动之前不会发生交易;t使用的是一个虚拟的时间量度,在时间t进行的交易按价格v计算。
输出格式
输出二哥的现金收益,保留两位小数(四舍五入)。
说明
对于所有数据:
m
≤
50
,
v
≤
200
,
a
≤
200
对于70%的数据:
n
≤
100
,
t
≤
10000
对于30%的数据:
n
≤
10000
,
t
≤
100000000
import java.util.*;import java.io.*;import java.text.*;import java.math.*;publicclassMain{publicstaticvoidmain(String[] args){try{
BufferedReader br =newBufferedReader(newInputStreamReader(System.in));int m = Integer.parseInt(br.readLine());
Record[] records =newRecord[m];for(int i =0; i < m; i++){
String[] parts = br.readLine().split(" ");
records[i]=newRecord(Integer.parseInt(parts[0]), Integer.parseInt(parts[1]), Integer.parseInt(parts[2]));}int n = Integer.parseInt(br.readLine());
Stock[] stocks =newStock[n];for(int i =0; i < n; i++){
String[] parts = br.readLine().split(" ");
stocks[i]=newStock(Integer.parseInt(parts[0]), Integer.parseInt(parts[1]));}double res =0;int mark =0;for(int i =0; i < m; i++){int t = records[i].t;int a = records[i].a;int d = records[i].d;int cur =0;for(; cur < n; cur++){if(stocks[cur].t > t)break;}double p = stocks[cur-1].v*a;
res -= Math.max(p*0.2,5);
res -= a*0.1;
res -=1;if(d ==1){
res -= p*100;}else{
res += p*99.9;}}
System.out.printf("%.2f\n", res);}catch(IOException e){
e.printStackTrace();}}}classRecord{int t;int a;int d;Record(int x,int y,int z){
t = x;
a = y;
d = z;}}classStock{int t;double v;Stock(int x,int y){
t = x;
v =(double)y;}}