A1022 Digital Library (30分)

Posted tsruixi

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了A1022 Digital Library (30分)相关的知识,希望对你有一定的参考价值。

一、技术总结

  1. 首先这是一个map,STL类型的题目,前面的一个问题是存储,首先可能会想到的是,把每个信息存储下来然后通过输入想要查询的方式进行查询。可是,如果这里会发现,是通过关键词然后查询输出,相关book的id号。这个样其实就可以使用map,把相关的关键词作为一个string,然后id使用一个set容器进行存储。
  2. 所以存储的形式就是map<string, set >
  3. 还有一点需要注意的是,查询函数query(),参数注意要使用引用,不然会有超时。
  4. 还有就是在输入一行中的单个字符串的时候,包括空格,应该怎么处理:
while(cin >> str){
    tkey[str].insert(id);
    char c = getchar();
    if(c == '
') break;
}

二、参考代码

#include<iostream>
#include<map>
#include<string>
#include<set>
using namespace std;
map<string, set<int> > ttitle, tkey, tauthor, tpub, tyear;
void query(map<string, set<int> > &m, string &str){
    if(m.find(str) != m.end()){
        for(auto it = m[str].begin(); it != m[str].end(); it++){
            printf("%07d
", *it);
        }
    }else{
        printf("Not Found
");
    }
}
int main(){
    int n, m, id, num;
    scanf("%d", &n);
    string title, key, author, pub, year;
    for(int i = 0; i < n; i++){
        scanf("%d
", &id);
        getline(cin, title);
        ttitle[title].insert(id);
        getline(cin, author);
        tauthor[author].insert(id);
        while(cin >> key){
            tkey[key].insert(id);
            char c = getchar();
            if(c == '
') break; 
        }
        getline(cin, pub);
        tpub[pub].insert(id);
        getline(cin, year);
        tyear[year].insert(id);
    }
    scanf("%d", &m);
    for(int i = 0; i < m; i++){
        scanf("%d: ", &num);
        string temp;
        getline(cin, temp);
        cout << num << ": " << temp << "
";
        if(num == 1) query(ttitle, temp);
        else if(num == 2) query(tauthor, temp);
        else if(num == 3) query(tkey, temp);
        else if(num == 4) query(tpub, temp);
        else if(num == 5) query(tyear, temp);
    }
    return 0;
}

以上是关于A1022 Digital Library (30分)的主要内容,如果未能解决你的问题,请参考以下文章

[PAT] A1022 Digital Library

1022 Digital Library (30)(30 分)

1022 Digital Library (30)(30 分)

1022 Digital Library (30)(30 point(s))

PAT Advanced 1022 Digital Library (30分)

PAT-1022 Digital Library (30 分) 字符串处理