题目描述

在数据库的操作过程中,我们进场会遇到检索操作。这个题目的任务是完成一些特定格式的检索,并输出符合条件的数据库中的所有结果。 
我们现在有一个数据库,维护了学生的姓名(Name),性别(Sex)以及出生日期(Birthday)。其中,Name项是长度不超过30的字符串,只可能包含大小写字母,没有空格;Sex项进可能为‘Male’或者‘Female’(不含引号);Birthday项以yyy/mm/dd的格式存储,如:1990/01/01, 
1991/12/31,等等。 
每个查询所可能包含的条件如下: 
Name=‘REQUIRED_NAME’,查询姓名为REQUIRED_NAME的学生,其中REQUIRED_NAME为长度在1到30之间的字符串; 
Sex=‘Male’或Sex=‘Female’,查询性别为男/女的学生; 
Birthday=‘yyy/mm/dd’,查询出生年/月/日为特定值的学生。如果其中某项为’’,则说明该项不受限制。例如,‘1990/06/’表示1990年6月出生,‘/03/’表示出生月份为3月。 
给定数据库的所有表项以及若干条查询,你需要对每条查询输出它返回的结果。 

输入

输入包含多组测试数据。输入的第一行为测试数据的组数T(1<=T<=50)。 
对于每组测试数据,第一行是两个整数N和M(N,M<=500),分别表示数据的数量以及查询的数量。 
接下来N行,每行以Name Sex Birthday的形式给出每个学生的信息。 
没下来M行,每行给出若干条限制条件,以空格隔开。条件以Name Sex Birthday的顺序给出(如果存在),且每种限制条件最多只出现一次。 

输出

对于每条查询,按照输入的顺序输出符合条件的学生姓名,每个一行。如果没有符合查询的信息,则输出一行NULL。

样例输入

1
5
6
Michael Male 1990/02/28
Amy Female 1992/04/03
Tom Male 1991/12/15
Lynn Female 1991/04/09
Zheng Male 1990/04/20
Name='Amy'
Name='Betty'
Sex='Female' Birthday='*/04/09'
Sex='Female' Birthday='*/*/*'
Name='Michael' Sex='Female'
Name='Michael' Sex='Male' Birthday='1990/02/*'

样例输出

Amy
NULL
Lynn
Amy
Lynn
NULL
Michael

来源

2014软院D题

。。。。。TLE了,具体原因是string用得太多,应改为char数组,TLE的版本。。。。↓

#include<iostream>
#include<cstdio>
#include<cmath>
#include<cstring>
#include<string>
#include<map>
using namespace std;
struct dog
{
string sex;
string birthday;
};
map<string,dog> donser;
bool deal(string a,string b)
{
string temp="/";
int pos1=a.find(temp[]);
int pos2=b.find(temp[]);
if(pos1==pos2)
{
string s1=a.substr(,pos1);
string s2=b.substr(,pos2);
if(s1!=s2)
return false;
}
a.erase(,pos1+);
b.erase(,pos2+);
pos1=a.find(temp[]);
pos2=b.find(temp[]);
if(pos1==pos2)
{
string s1=a.substr(,pos1);
string s2=b.substr(,pos2);
if(s1!=s2)
return false;
}
a.erase(,pos1+);
b.erase(,pos2+);
if(a.size()==b.size())
{
if(a!=b)
return false;
}
return true;
}
int main()
{
int tes,m,n;
//freopen("test.out","w",stdout);
while(~scanf("%d",&tes))
{
while(tes--)
{
cin>>m>>n;
while(m--)
{
string a,b,c;
cin>>a>>b>>c;
donser[a].sex=b;
donser[a].birthday=c;
}
cin.get();
while(n>)
{
n--;
string str,temp="a'a",c_name="",c_sex="",c_birth="";
bool lable=false,named=false,sexd=false,birthd=false;
getline(cin,str);
if(str[]=='N')
{
str.erase(,);
int pos=str.find(temp[]);
c_name=str.substr(,pos);
named=true;
str.erase(,pos+);
if( donser.find(c_name)==donser.end())
{
cout<<"NULL"<<endl;
continue;
}
if(str.size()>)
str.erase(,);
}
if(str.size()>&&str[]=='S')
{
str.erase(,);
int pos=str.find(temp[]);
c_sex=str.substr(,pos);
sexd=true;
str.erase(,pos+);
if(str.size()>)
str.erase(,);
}
if(str.size()>&&str[]=='B')
{
str.erase(,);
int pos=str.find(temp[]);
c_birth=str.substr(,pos);
birthd=true;
str="";
}
if(named)
{
if((donser[c_name].sex==c_sex||sexd==false)&&(deal(donser[c_name].birthday,c_birth)||birthd==false))
cout<<c_name<<endl;
else
cout<<"NULL"<<endl;
}
else
{
map<string,dog>::iterator it;
for(it=donser.begin();it!=donser.end();it++)
{
if((it->second.sex==c_sex||sexd==false)&&(deal(it->second.birthday,c_birth)||birthd==false))
{
cout<<it->first<<endl;
lable=true;
}
}
if(lable==false)
cout<<"NULL"<<endl;
}
}
donser.clear();
}
}
return ;
}

BUPT复试专题—数据库检索(2014软院)的更多相关文章

  1. BUPT复试专题—奇偶求和(2014软件)

    题目描述 给出N个数,求出这N个数,奇数的和以及偶数的和. 输入 第一行为测试数据的组数T(1<=T<=50).请注意,任意两组测试数据之间是相互独立的. 每组数据包括两行: 第一行为一个 ...

  2. BUPT复试专题—网络传输(2014网研)

    题目描述 网络的高效互联与智能传输是提升海量用户服务请求映射效率的重要措施.在这个任务中,你需耍在最小的传输时间内,将数据源传输到指定的网络节点中.我们给定的网络一共包含N个节点,其中节点1为数据源. ...

  3. BUPT复试专题—进程管理(2014网研)

    题目描述 在操作系统中,进程管理是非常重要的工作.每个进程都有唯一的进程标识PID.每个进程都可以启动子进程,此时我们称该它本身是其子进程的父进程.除PID为0的进程之外,每个进程冇且只冇一个父进程. ...

  4. BUPT复试专题—分数加法(2014网研)

    题目描述 求2^-a + 2^-b,其中a和b均为正整数,结果用最简分数表示 输入 第一行为测试数据的组数T (1~400).请注意,任意两组测试数据之间相互独立的.每组测试数据一行,包含两个整数a和 ...

  5. BUPT复试专题—Python List(2014)

    题目描述 在Python中,List (列表)是一种非常重要的数据结构.它与C/C++/Java中的 数组有些类似,但支持添加新元素时的动态扩展.在这个问题中,你需要处理如下 的几种对List的操作. ...

  6. BUPT复试专题—字符串转换(2013计院)

    题目描述 我们将仅由若干个同一小写字母构成的字符串称之为简单串,例如"aaaa"是一个简单串,而"abcd"则不是简单串.现在给你一个仅由小写字母组成的字符串, ...

  7. BUPT复试专题—统计时间间隔(2013计院)

    题目描述 给出两个时间(24小时制),求第一个时间至少要经过多久才能到达第二个时间.给出的时间一定满足的形式,其中x和y分别代表小时和分钟.0≤x<24,0≤y<60. 输入格式 第一行为 ...

  8. BUPT复试专题—最近公共祖先(2014软院)

    题目描述 给出一棵有N个节点的有根树TREE(根的编号为1),对于每组查询,请输出树上节点u和v的最近公共祖先. 最近公共祖先:对于有向树TREE的两个结点u,v.最近公共祖先LCA(TREE u,v ...

  9. BUPT复试专题—最长连续等差子数列(2014软院)

    题目描述   给定-个长度为N的整数数列,你需要在其中找到最长的连续子数列的长度, 并满足这个子数列是等差的.注意公差小于或等于0的情况也是允许的. 输入 第一行为数据组数T(1~100),表示测试数 ...

随机推荐

  1. python 学习第二周总复习

    目录 数据类型内置方法 数字类型内置方法 整型 浮点型 字符串类型内置方法 列表类型内置方法 元祖类型内置方法 字典类型内置方法 集合类型内置方法 布尔类型 数据类型总结 拷贝 浅拷贝 深拷贝 053 ...

  2. 守护进程,互斥锁,IPC,生产者与消费者模型

    守护进程: b 进程守护 a进程,当a进程执行完毕时,b进程会跟着立马结束 守护进程用途: 如果父进程结束了,子进程无需运行了,就可以将子进程设置为父进程的守护进程 例如我们qq视频聊天时,当我们退出 ...

  3. read content in a text file in python

    ** read text file in pythoncapability: reading =text= from a text file 1. open the IDLE text editor  ...

  4. LeetCode 673. Number of Longest Increasing Subsequence

    Given an unsorted array of integers, find the number of longest increasing subsequence. Example 1: I ...

  5. BFS:UVa201-Squares

    Squares A children's board game consists of a square array of dots that contains lines connecting so ...

  6. Bin Paking Problem:简单的构造性算法

    *本文主要记录和分享学习到的知识,算不上原创 *参考文献见链接 目录 BL和BLF算法 BF算法 HR算法 PH算法

  7. 二分查找与 bisect 模块

    Python 的列表(list)内部实现是一个数组,也就是一个线性表.在列表中查找元素可以使用 list.index() 方法,其时间复杂度为O(n).对于大数据量,则可以用二分查找进行优化.二分查找 ...

  8. ci $this->load->database()

    http://pengbotao.cn/codeigniter-database.html

  9. PTA 10-排序4 统计工龄 (20分)

    题目地址 https://pta.patest.cn/pta/test/15/exam/4/question/721 5-13 统计工龄   (20分) 给定公司NN名员工的工龄,要求按工龄增序输出每 ...

  10. 算法复习——2—sat(bzoj2199)

    题目: Description 由于对Farmer John的领导感到极其不悦,奶牛们退出了农场,组建了奶牛议会.议会以“每头牛 都可以获得自己想要的”为原则,建立了下面的投票系统: M只到场的奶牛 ...