Problem21运算符重载、字符串处理

2020-07-07

居然用了将近2h···心态崩了,看来熟练度还需要加强啊

解题思路:处理各种类型的运算符重载+字符串处理

比较运算符

bool Computer::operator<(const Computer& src) const{
    if (storage<src.storage) {
        return true;
    }else if(storage>src.storage){
        return false;
    }else if(price<src.price){
        return true;
    }else return false;
}

两个要点。
一是函数类型,函数必须是const函数。如果只是自己随便用用的话函数类型不加const也可以,但是希望调用STL当中的sort函数,sort函数要求定义<运算,并且规定了函数类型。
一是比较逻辑。必须对于storage的<和>的情况都进行比较,之后再对price进行比较。容易产生的错误写法如下,漏掉对storage>的判断:

bool Computer::operator<(const Computer& src) const{
    if (storage<src.storage) {
        return true;
    }else if(price<src.price){
        return true;
    }else return false;
}

前缀、后缀自增自减运算符

Computer& Computer::operator--(){
    if (storage>0) {
        --storage;
    }
    return *this;
}

Computer& Computer::operator++(){
    ++storage;
    return *this;
}


Computer Computer::operator--(int){
    Computer c(name,storage,price);
    if (storage>0) {
        --storage;
    }
    return c;
}

Computer Computer::operator++(int){
    Computer c(name,storage,price);
    ++storage;
    return c;
}

要点:

  1. 后缀方式实现的自增自减和前缀的返回值类型以及实现方式都并不同
  2. ++t这种调用方式是【前缀】,别搞混了。

流运算符重载

friend ostream& operator<< (ostream& out, const Computer& src);
ostream& operator<< (ostream& out, const Computer& src){
    out<<src.name<<"-num-"<<src.storage<<"-price-"<<src.price;
    return out;
}
friend istream& operator>> (istream& in, ComputerCollection& dst);
friend ostream& operator<< (ostream& out, const ComputerCollection& src);

istream& operator>> (istream& in, ComputerCollection& dst){
    string s;cin>>s;
    Computer c(s);
    dst.cc.push_back(c);
    return in;
}
ostream& operator<< (ostream& out, const ComputerCollection& src){
    for (int i=src.cc.size()-1; i>=0; i--) {
        out<<src.cc[i]<<endl;
    }
    return out;
}

比较坑的地方在于分清“in”“out”和“cin”“cout”······这里一不小心就容易手抖。

数组下标运算符重载

Computer& operator[](int index);
Computer& operator[](string name);

Computer& ComputerCollection::operator[](int index){
    return cc[index];
}

Computer& ComputerCollection::operator[](string name){
    for (int i=0; i<cc.size(); i++) {
        if (cc[i].myName()==name) {
            return cc[i];
        }
    }
    return cc[0];
}

这个也没有什么很坑的地方

字符串截取

输入输出字符串需要截取其中的一部分。这个使用find函数就可以做到。大不了多用几次。

    int t=s.find("-");
    name = s.substr(0,t);
    s=s.substr(t+1,s.length());

题目

题目描述

中关村有家电脑商城想要录入店内各种型号电脑的存货及价格并进行销售,要求:

  1. 从输入文件中读取电脑的型号,存货与价格。
  2. 按照输入文件中的操作,对电脑的几个参数进行修改。
  3. 按照库存从大到小对所有电脑进行排序。若库存相同,则按价格从高到底排(保证不存在库存与价格均相同)。并输出。

输入样例

第一行是电脑型号数n。

接下来n行是对电脑的参数描述,每行是一种型号电脑的名字-库存-价格

然后是所有操作数m,接下来m行每行一个操作,操作类型有四种:

  • ASK A B:询问A,B两种电脑哪个库存更多(若库存相同,则先输出价格更高的。保证不存在库存与价格均相同的两种电脑)。按顺序输出两种电脑的名字-库存-价格
  • SELL A:卖出A电脑,A电脑库存减一(当库存为零时,该操作无效,即库存不变),输出A电脑的名字-库存-价格
  • BUY A:买进A电脑,A电脑库存加一,输出A电脑的名字-库存-价格
  • CHANGE A q:A电脑价格更改为q(q不为负数),输出A电脑的名字-库存-价格
4
samsung-10-91
lenovo-9-88
mac-8-3
thinkpad-1-90
8
ASK samsung lenovo
SELL thinkpad
SELL samsung
BUY mac
BUY lenovo
SELL thinkpad
ASK samsung lenovo
CHANGE mac 92

输出样例

先输出m组操作的结果。ASK操作的结果为三行,第一行为库存更多的(或库存一样多,价格更高的)电脑,第二行为另一台电脑,第三行是空行;其余操作仅输出两行,第一行为被操作电脑,第二行是空行。

再输出n行,是排名的结果,库存高的电脑先输出,若库存相同,则价格高的先输出。

samsung-num-10-price-91
lenovo-num-9-price-88

thinkpad-num-0-price-90

samsung-num-9-price-91

mac-num-9-price-3

lenovo-num-10-price-88

thinkpad-num-0-price-90

lenovo-num-10-price-88
samsung-num-9-price-91

mac-num-9-price-92

lenovo-num-10-price-88
mac-num-9-price-92
samsung-num-9-price-91
thinkpad-num-0-price-90

要求

下列代码的基础上,编写Computer类和ComputerCollection类的代码,完成上述要求。

main.cpp:

#include "Computer.h"
#include "ComputerCollection.h"
#include <iostream>
#include <string>
using namespace std;

int main() {
  int n;
  cin >> n;

  ComputerCollection cc;
  for(int i = 0; i < n; i++){
    cin >> cc;
  }

  int m;
  cin >> m;

  for(int i = 0; i < m; i++){
    string opt, nameA, nameB;
    cin >> opt;
    if (opt == "ASK"){
        cin >> nameA >> nameB;
        if(cc[nameA] < cc[nameB]){
          cout << cc[nameB] << "\n" << cc[nameA] << "\n" << endl ;
        }else{
          cout << cc[nameA] << "\n" << cc[nameB] << "\n" << endl;
        }
    } else if (opt == "SELL"){
        cin >> nameA;
        --cc[nameA];
        cout << cc[nameA] << "\n" << endl;        
    } else if (opt == "BUY"){
        cin >> nameA;
        ++cc[nameA];
        cout << cc[nameA] << "\n" << endl;
    } else if (opt == "CHANGE"){
        string price;
        cin >> nameA >> price;
        cc[nameA].setPrice(atoi(price.data()));
        cout << cc[nameA] << "\n" << endl;
    } else{
      continue;
    }
  }

  cc.sortByScore();
  cout << cc;

  return 0;
}

makefile:

all: main

main: main.o Computer.o ComputerCollection.o
    g++ main.o Computer.o ComputerCollection.o -o main -O2 -std=c++11

main.o: main.cpp Computer.cpp ComputerCollection.cpp
    g++ -c main.cpp -o main.o -O2 -std=c++11

ComputerCollection.o: ComputerCollection.cpp Computer.cpp
    g++ -c ComputerCollection.cpp -o ComputerCollection.o -O2 -std=c++11

Computer.o: Computer.cpp
    g++ -c Computer.cpp -o Computer.o -O2 -std=c++11

clean: 
    rm -fR *.o main

提交格式

你需要写多个文件,包含上述文件调用的各种头文件及其cpp文件;可以不包括提供的main.cpp文件。你应该将你的文件打包成一个zip压缩包并上传。评测时,OJ会将提供的main.cpp贴入你的目录下进行编译并执行。

评分标准

OJ评分占100%。


最终提交文件

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 218,607评论 6 507
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,239评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 164,960评论 0 355
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,750评论 1 294
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,764评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,604评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,347评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,253评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,702评论 1 315
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,893评论 3 336
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,015评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,734评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,352评论 3 330
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,934评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,052评论 1 270
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,216评论 3 371
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,969评论 2 355