亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 學院 > 開發設計 > 正文

CCF201412-3 集合競價(100分)

2019-11-10 17:29:27
字體:
來源:轉載
供稿:網友

問題鏈接:CCF201412試題。

問題描述

  某股票交易所請你編寫一個程序,根據開盤前客戶提交的訂單來確定某特定股票的開盤價和開盤成交量。  該程序的輸入由很多行構成,每一行為一條記錄,記錄可能有以下幾種:  1. buy p s 表示一個購買股票的買單,每手出價為p,購買股數為s。  2. sell p s 表示一個出售股票的賣單,每手出價為p,出售股數為s。  3. cancel i表示撤銷第i行的記錄。  如果開盤價為p0,則系統可以將所有出價至少為p0的買單和所有出價至多為p0的賣單進行匹配。因此,此時的開盤成交量為出價至少為p0的買單的總股數和所有出價至多為p0的賣單的總股數之間的較小值。  你的程序需要確定一個開盤價,使得開盤成交量盡可能地大。如果有多個符合條件的開盤價,你的程序應當輸出最高的那一個。  輸入數據有任意多行,每一行是一條記錄。保證輸入合法。股數為不超過108的正整數,出價為精確到恰好小數點后兩位的正實數,且不超過10000.00。  你需要輸出一行,包含兩個數,以一個空格分隔。第一個數是開盤價,第二個是此開盤價下的成交量。開盤價需要精確到小數點后恰好兩位。問題分析:這是一個競價匹配的問題。數據可以存儲在結構數組中,但未必是好的方案。使用兩個優先隊列,一個用于存儲購入訂單,按價格從大到小排列;另外一個用于存儲賣出訂單,按價格從小到大排列;然后進行價格的匹配處理。

程序說明:(略)。

提交后得100分的C++語言程序如下:

/* CCF201412-3 集合競價 */#include <iostream>#include <queue>#include <cstring>#include <cstdio>using namespace std;const int N = 5000;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 // t == 'b'            return price < n.price;    }};bool cancelflag[N+1];int main(){    trading t;    priority_queue<trading> 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.trading[0] == 's'                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 {    // b.quantity < s.quantity                buy.pop();                s.quantity -= b.quantity;                sell.pop();                sell.push(s);            }        } else            break;    }    // 輸出結果    printf("%.2f", t.price);    cout << " " << t.quantity << endl;    return 0;}/*測試樣例:sell 8.88 100sell 8.88 175sell 9.00 400buy 8.88 400cancel 1sell 100.00 508.88 175buy 9.25 100buy 8.88 175buy 9.00 400sell 8.88 400cancel 1buy 100.00 509.00 400buy 9.25 100buy 8.88 175buy 9.00 400sell 8.79 1501cancel 1cancel 29.00 400buy 9.25 110buy 8.88 300buy 18.88 200sell 8.88 201sell 9.25 1009.25 301*/


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
91精品国产91久久久久| 5566成人精品视频免费| 欧美精品久久久久久久免费观看| 亚洲欧美另类中文字幕| 欧美性做爰毛片| 91精品国产自产在线观看永久| 国产精品亚洲欧美导航| 成人乱色短篇合集| 91免费看国产| 日韩在线观看精品| 亚洲国产精品久久久久秋霞不卡| 国产主播欧美精品| 欧美日韩国产中字| 欧美特黄级在线| 51色欧美片视频在线观看| 成人免费网站在线观看| 日本久久久a级免费| 中文字幕日韩专区| 日本成人在线视频网址| 国产精品久久久999| 欧美午夜视频在线观看| 久久久精品久久久久| 8090成年在线看片午夜| 国产午夜精品麻豆| 亚洲永久免费观看| 日韩av在线免费看| 欧美中文在线免费| 欧美在线视频播放| 91九色精品视频| 久久91超碰青草是什么| 久久人91精品久久久久久不卡| 欧美性极品xxxx娇小| 欧美亚洲激情视频| 欧美激情精品久久久久| 色樱桃影院亚洲精品影院| 久久久精品一区二区三区| 久久精品国产99国产精品澳门| 色综合亚洲精品激情狠狠| 国产日韩在线亚洲字幕中文| 欧美精品久久久久久久| 少妇激情综合网| 国产精品人成电影在线观看| 日韩精品在线免费观看视频| 色综合久久88色综合天天看泰| 欧美激情视频免费观看| 美女视频黄免费的亚洲男人天堂| 日韩女优人人人人射在线视频| 久久久国产精品视频| 伊人伊成久久人综合网小说| 在线日韩av观看| 久久777国产线看观看精品| www.欧美三级电影.com| 久久影院免费观看| 国产精品欧美日韩久久| 国产91热爆ts人妖在线| 日本精品一区二区三区在线| 亚洲精选中文字幕| 亚洲国产成人在线视频| 国产成人在线视频| 久久久精品在线观看| 2019亚洲日韩新视频| 日韩av免费在线观看| 91精品国产沙发| 福利视频一区二区| 97视频在线观看亚洲| 国产精品毛片a∨一区二区三区|国| 成人h视频在线| 成人羞羞国产免费| 亚洲色无码播放| 欧美国产第二页| 91爱视频在线| 亚洲欧美制服另类日韩| 538国产精品一区二区在线| 欧美影院久久久| 国产精品久久久久久久久久久久久| 亚洲欧美日韩精品久久| 欧美日本在线视频中文字字幕| 91精品久久久久久久久久另类| 亚洲黄色av女优在线观看| 午夜精品久久久久久99热| 欧美成人一区二区三区电影| 最近更新的2019中文字幕| 91久久精品美女| 欧美裸体视频网站| 日韩欧美国产黄色| 欧美一区二区三区艳史| 亚洲国产成人精品久久久国产成人一区| 久久伊人精品一区二区三区| 青草青草久热精品视频在线观看| 97国产在线观看| 69久久夜色精品国产69| 大伊人狠狠躁夜夜躁av一区| 激情成人在线视频| 欧美裸体xxxxx| 欧美电影第一页| 国产欧美日韩91| 日韩电影免费观看在线| 超碰日本道色综合久久综合| 欧美裸体xxxx极品少妇软件| 欧美激情一区二区久久久| 欧美电影《睫毛膏》| 欧美激情图片区| 国产精品久久久久久久久久新婚| 国产精品视频免费在线观看| 国产成人精品免费久久久久| 久久中文字幕国产| 久久在线视频在线| 亚洲在线免费看| 久久国产色av| 国产免费成人av| 亚洲自拍偷拍在线| 欧美巨猛xxxx猛交黑人97人| 日韩国产精品亚洲а∨天堂免| 欧美日韩国产第一页| 亚洲一区二区免费| 亚洲网站在线观看| 91美女福利视频高清| 亚洲精品自产拍| 国产亚洲精品高潮| 亚洲美女在线观看| 亚洲成人av在线播放| 疯狂做受xxxx高潮欧美日本| 欧洲中文字幕国产精品| 午夜精品一区二区三区在线视频| 亚洲性猛交xxxxwww| 91九色单男在线观看| 久久久久久一区二区三区| 欧美巨大黑人极品精男| 综合欧美国产视频二区| 成人福利网站在线观看11| 久久久久久久电影一区| 亚洲最新av在线网站| 国产精品自产拍在线观| 一区二区三区视频观看| 欧美诱惑福利视频| 欧美在线日韩在线| 国产精品你懂得| 国产精品视频午夜| 91精品视频免费看| 亚洲色图在线观看| 欧美日韩美女在线| 九九热99久久久国产盗摄| 欧美日韩性视频| 欧美日韩在线影院| 一本大道亚洲视频| 亚洲v日韩v综合v精品v| 成人美女免费网站视频| 伦伦影院午夜日韩欧美限制| 中文字幕久热精品在线视频| 日本久久久a级免费| 91老司机在线| 91成人免费观看网站| 亚洲激情电影中文字幕| 亚洲国产精品网站| 亚洲精品综合久久中文字幕| 色偷偷av一区二区三区| 欧美成人四级hd版| 在线观看欧美日韩| 亚洲最新视频在线| 一区二区三区视频在线| 欧美极品少妇与黑人| 亚洲欧美一区二区三区四区| 国内精品久久久久久久| 国产在线拍偷自揄拍精品|