通讯录中的一条记录包含下述基本信息:朋友的姓名、出生日期、性别、固定电话号码、移动电话号码。 本题要求编写程序,录入N条记录,并且根据要求显示任意某条记录。
输入格式:
输入在第一行给出正整数N(≤10);随后N行,每行按照格式姓名 生日 性别 固话 手机
给出一条记录。其中姓名是不超过10个字符、不包含空格的非空字符串;生日按yyyy/mm/dd
的格式给出年月日;性别用M
表示“男”、F
表示“女”;固话和手机均为不超过15位的连续数字,前面有可能出现+。
在通讯录记录输入完成后,最后一行给出正整数K,并且随后给出K个整数,表示要查询的记录编号(从0到N−1顺序编号)。数字间以空格分隔。
输出格式:
对每一条要查询的记录编号,在一行中按照姓名 固话 手机 性别 生日
的格式输出该记录。若要查询的记录不存在,则输出Not Found
。
输入样例1:
3
Chris 1984/03/10 F +86181779452 13707010007
LaoLao 1967/11/30 F 057187951100 +8618618623333
QiaoLin 1980/01/01 M 84172333 10086
2 1 7
输出样例1:
LaoLao 057187951100 +8618618623333 F 1967/11/30
Not Found
输入样例2:(编号输入可为负数)
Chris 1984/03/10 F +86181779452 13707010007
LaoLao 1967/11/30 F 057187951100 +8618618623333
QiaoLin 1980/01/01 M 84172333 10086
2 1 -1
输出样例2:
LaoLao 057187951100 +8618618623333 F 1967/11/30
Not Found
【源代码】
#include <iostream>
#include <vector>
#include <string>
using namespace std;
class Person
{
public:
string sName = ""; // 姓名;
string sBirth = ""; // 生日;
char cGender = ' '; // 性别;
string sTP = ""; // 固话;
string sMP = ""; // 手机;
Person(string sName, string sBirth, char cGender, string sTP, string sMP);
Person(); // 默认构造函数;
~Person(); // 默认析构函数;
};
Person::Person()
{
}
Person::~Person()
{
}
Person::Person(string Name, string Birth, char Gender, string TP, string MP)
{
this-> sName = Name;
this-> sBirth = Birth;
this-> cGender = Gender;
this-> sTP = TP;
this-> sMP = MP;
}
int main()
{
int N;
cin >> N;
vector<Person> People;
string sName = ""; // 姓名;
string sBirth = ""; // 生日;
char cGender = ' '; // 性别;
string sTP = ""; // 固话;
string sMP = ""; // 手机;
for (int i = 0; i < N; i++)
{
cin >> sName;
cin >> sBirth;
cin >> cGender;
cin >> sTP >> sMP;
People.push_back(Person(sName, sBirth, cGender, sTP, sMP));
}
int K;
cin >> K;
int Num; // 编号
for (int i = 0; i < K; i++)
{
cin >> Num;
if ((0 <= Num) && (Num < N)) // 保证查询的记录编号在范围[0, N-1]内;
{
cout << People[Num].sName << " ";
cout << People[Num].sTP << " ";
cout << People[Num].sMP << " ";
cout << People[Num].cGender << " ";
cout << People[Num].sBirth << endl;
}
else
{
cout << "Not Found" << endl;
}
}
return 0;
}