PAT甲题题解-1022. Digital Library (30)-map映射+vector
博主欢迎转载,但请给出本文链接,我尊重你,你尊重我,谢谢~
http://www.cnblogs.com/chenxiwenruo/p/6789235.html
特别不喜欢那些随便转载别人的原创文章又不给出链接的
所以不准偷偷复制博主的博客噢~~
题意:
给出n本书的id、名称、作者、多个关键词、出版社、出版年
然后给出m个查询,每个查询包含查询的种类、对应的内容
针对每个查询,让你输出所有符合的书的id,从小到大排序,没有的话则输出No Found
首先把每个book的信息都读取处理好,然后按照id排个序,因为最后查询需要按照id的增序输出
重新遍历所有的book,对于book的每个信息string,通过build_map()建立一下映射
由于有5种类别,所以分开建立映射maps[1]~maps[5]
(因为可能会存在不同类别会出现相同的string)
这样就把每种类型的string和vector数组book_id的索引值建立起来,vector数组存储对应的book id
由于最多有10000个书,那么就至少有10000个title和10000个auther
题目中还说了最多1000个不同的keywords和1000个不同的publisher
year的范围是1000~3000,则最多有2000个
所以映射值最多为24000个,即vector的数组大小要>24000,否则会出现段错误越界
然后对于查询的种类k和字符串string
找出映射值maps[k][string],如果为0,则说明找不到,输出No Found
如果为某个值idx,那么访问vector数组book_id[idx],存储的即是对应书的id
#include <iostream>
#include <cstdio>
#include <algorithm>
#include <cstring>
#include <map>
#include <vector>
#define TITLE 1
#define AUTHER 2
#define KEYWORDS 3
#define PUBLISHER 4
#define YEAR 5
using namespace std;
const int maxn=+;
int n;
int cnt=;
map<string,int>maps[]; struct Book{
int id;
string title;
string author;
string keywords[];
int keynum;
string publisher;
string year;
bool operator<(const Book tmp)const{
return id<tmp.id;
}
}book[maxn]; vector<int> book_id[maxn*]; void readKeywords(char*str,int i){
//按照定义的分隔符d来分割字符串,对keyword进行读取
const char *d = " ";//空格
char *p;
p = strtok(str,d);
int idx=;
//这样做的主要原因是避免最后输出换行
while(p)
{
book[i].keywords[idx]=p;
idx++;
p=strtok(NULL,d); //读取下一个p
}
book[i].keynum=idx;
}
/**
建立k、string的映射
*/
void build_map(string s,int i,int k){
if(maps[k][s]==)
maps[k][s]=++cnt;
book_id[maps[k][s]].push_back(i);
}
int main()
{
char str[];
scanf("%d",&n);
for(int i=;i<n;i++){
scanf("%d",&book[i].id);
getchar(); //这里是读取id后面的换行符
gets(str);
book[i].title=str; gets(str);
book[i].author=str; gets(str);
readKeywords(str,i); gets(str);
book[i].publisher=str; gets(str);
book[i].year=str;
}
sort(book,book+n);
//建立映射,顺便存储书的id
for(int i=;i<n;i++){
build_map(book[i].title,i,TITLE);
build_map(book[i].author,i,AUTHER);
for(int j=;j<book[i].keynum;j++)
build_map(book[i].keywords[j],i,KEYWORDS);
build_map(book[i].publisher,i,PUBLISHER);
build_map(book[i].year,i,YEAR);
}
int m;
int kind;
scanf("%d",&m);
for(int i=;i<m;i++){
scanf("%d:",&kind);
getchar();
gets(str);
printf("%d: %s\n",kind,str);
string s=str;
int map_id=maps[kind][s];
if(map_id==)
printf("Not Found\n");
else{
for(int j=;j<book_id[map_id].size();j++){
int bid=book_id[map_id][j];
printf("%07d\n",book[bid].id);
}
}
}
return ;
}
PAT甲题题解-1022. Digital Library (30)-map映射+vector的更多相关文章
- 1022. Digital Library (30) -map -字符串处理
题目如下: A Digital Library contains millions of books, stored according to their titles, authors, key w ...
- PAT甲题题解-1030. Travel Plan (30)-最短路+输出路径
模板题最短路+输出路径如果最短路不唯一,输出cost最小的 #include <iostream> #include <cstdio> #include <algorit ...
- PAT甲题题解-1103. Integer Factorization (30)-(dfs)
该题还不错~. 题意:给定N.K.P,使得可以分解成N = n1^P + … nk^P的形式,如果可以,输出sum(ni)最大的划分,如果sum一样,输出序列较大的那个.否则输出Impossible. ...
- PAT甲题题解-1004. Counting Leaves (30)-统计每层叶子节点个数+dfs
统计每层的叶子节点个数建树,然后dfs即可 #include <iostream> #include <cstdio> #include <algorithm> # ...
- PAT甲题题解-1072. Gas Station (30)-dijkstra最短路
题意:从m个加油站里面选取1个站点,使得其离住宅的最近距离mindis尽可能地远,并且离所有住宅的距离都在服务范围ds之内.如果有很多相同mindis的加油站,输出距所有住宅平均距离最小的那个.如果平 ...
- PAT甲题题解-1091. Acute Stroke (30)-BFS
题意:给定三维数组,0表示正常,1表示有肿瘤块,肿瘤块的区域>=t才算是肿瘤,求所有肿瘤块的体积和 这道题一开始就想到了dfs或者bfs,但当时看数据量挺大的,以为会导致栈溢出,所以并没有立刻写 ...
- PAT甲题题解-1107. Social Clusters (30)-PAT甲级真题(并查集)
题意:有n个人,每个人有k个爱好,如果两个人有某个爱好相同,他们就处于同一个集合.问总共有多少个集合,以及每个集合有多少人,并按从大到小输出. 很明显,采用并查集.vis[k]标记爱好k第一次出现的人 ...
- pat 甲级 1022. Digital Library (30)
1022. Digital Library (30) 时间限制 1000 ms 内存限制 65536 kB 代码长度限制 16000 B 判题程序 Standard 作者 CHEN, Yue A Di ...
- PAT 甲级 1022 Digital Library (30 分)(字符串读入getline,istringstream,测试点2时间坑点)
1022 Digital Library (30 分) A Digital Library contains millions of books, stored according to thei ...
随机推荐
- java调用Linux执行Python爬虫,并将数据存储到elasticsearch--(环境脚本搭建)
java调用Linux执行Python爬虫,并将数据存储到elasticsearch中 一.以下博客代码使用的开发工具及环境如下: 1.idea: 2.jdk:1.8 3.elasticsearch: ...
- SDN2017 第三次实验作业
实验目的 在给定如上实验拓扑情况下,用vlan得到下列虚拟网段 h1--h4互通 h2--h5互通 h3--h6互通 其余主机间无法通信 实验步骤 1. 创建拓扑 #! /usr/bin/python ...
- 分享-结合demo讲解JS引擎工作原理
代码如下: var x = 1; function A(y){ var x = 2; function B(z){ console.log(x+y+z); } return B; } var C = ...
- initialProps被React-Navigation的navigation属性覆盖解决方案
怎么开场对我来说一个是个很纠结的问题,Emmm这应该算个好开场. 最近在做一个RN的app端调试工具,在把它嵌入原生app中的时候遇到了一个问题,RN组件里面接受不到原生传过来的initialProp ...
- sublime text3 setting-user
{ "caret_style": "smooth", "find_selected_text": true, "font_size ...
- Oracle修改表空间为自动扩展
https://gqsunrise.iteye.com/blog/2015692 1.数据文件自动扩展的好处1)不会出现因为没有剩余空间可以利用到数据无法写入2)尽量减少人为的维护3)可以用于重要级别 ...
- mac apache的使用
因为apache的安装目录/private/etc是默认隐藏的,所以我们需要通过文件夹前往/命令行的方法去找. 或命令行中输入: userdeMBP:~ user$ open /etc 然后都会打开相 ...
- 【转】Android7.0适配心得
本文出自:贾鹏辉的技术博客(http://www.devio.org) http://www.devio.org/2016/09/28/Android7.0%E9%80%82%E9%85%8D%E5% ...
- PAT B1040 有几个PAT (25 分)
字符串 APPAPT 中包含了两个单词 PAT,其中第一个 PAT 是第 2 位(P),第 4 位(A),第 6 位(T):第二个 PAT 是第 3 位(P),第 4 位(A),第 6 位(T). 现 ...
- Python2.7-fileinput
fileinput 模块,对输入的文件流进行迭代操作,可以说是对 open() 的一个扩展,它可以直接修改文件,也可以对他们进行备份 模块方法: fileinput.input([files[, in ...