我需要帮助尝试搜索一个类对象数组。我有一个名为users的类,并且有一个存储3个玩家的数组。我希望能够在输入他的两个名字时显示特定玩家的信息,并在输入姓名时删除他的记录。
据我所知,我可以使用矢量列表来简化这一过程,但我设置了限制。我也认为可以实现线性搜索,但我不知道这是否足够有效。
#include <iostream>
#include <string>
#include <math.h>
using namespace std;
void storeinfo() ;
void showinfo() ;
void menu() ;
class user
{
string firstname, lastname, currentteam, position, status ;
int age ;
public:
user() {};
user(string fname, string lname, string cteam, string pos, string stat, int age)
{
setFirstName(fname);
setLastName(lname);
setCurrentTeam(cteam);
setPosition(pos);
setStatus(stat);
setAge(age);
} ;
void setFirstName(string fname)
{firstname = fname;}
void setLastName(string lname)
{lastname = lname;}
void setCurrentTeam(string cteam)
{currentteam = cteam;}
void setPosition(string pos)
{position = pos;}
void setStatus(string stat)
{status = stat;}
void setAge(int _age)
{age = _age;}
string getFirstName()
{return firstname ;}
string getLastName()
{return lastname ;}
string getCurrentTeam()
{return currentteam ;}
string getPosition()
{return position ;}
string getStatus()
{return status ;}
int getAge()
{return age ;}
};
user player[20] ;
int main()
{
menu() ;
cin.get() ;
return 0 ;
}
void storeinfo()
{
string firstname ;
string lastname ;
string currentteam ;
string position;
string status ;
int age ;
for (int i=0; i < 3; i++)
{
cout << "Enter First Name : " ;
cin >> firstname ;
player[i].setFirstName(firstname) ;
cout << "Enter Last Name : " ;
cin >> lastname ;
player[i].setLastName(lastname) ;
cout << "Enter Player's Age : " ;
cin >> age;
player[i].setAge(age) ;
cout << "Enter Current Team : " ;
cin >> currentteam ;
player[i].setCurrentTeam(currentteam) ;
cout << "Enter Position : " ;
cin >> position ;
player[i].setPosition(position) ;
cout << "Enter Status : " ;
cin >> status ;
player[i].setStatus(status) ;
cout << "\n\n\n" ;
}
/*cout << string(50, '\n');*/
menu() ;
}
void showinfo()
{
for (int i=0; i < 3; i++)
{
cout << "First Name : " << player[i].getFirstName() << "\n" << "Last Name : " << player[i].getLastName() <<
"\n" << "Age : " << player[i].getAge() << "\n" << "Current Team : " << player[i].getCurrentTeam() <<
"\n" << "Position : " << player[i].getPosition() << "\n" << "Status : " << player[i].getStatus() << "\n\n";
}
cin.get() ;
menu() ;
}
void menu()
{
cout << "\n MENU" << "\n" ;
cout << "\n 1. Store Player Information" ;
cout << "\n 2. Show Player Informaton" ;
cout << "\n 0. Exit \n \n" ;
string x = "";
cin >> x ;
if (x=="a")
{
storeinfo() ;
}
else if (x=="b")
{
showinfo() ;
}
else if (x=="c")
{
exit(0) ;
}
else
{
cout << "Invalid Choice" ;
menu() ;
}
}
我已经完成了线性搜索算法并且似乎正在工作,但我得到的输出不正确,下面是两个函数的代码,再次感谢
int linsearch(string val)
{
for (int j=0; j < 3; j++)
{
if (player[j].getLastName()==val)
{
return j;
}
else
{
return 1;
}
}
void showinfo()
{
string search;
int found ;
cout << "Please Enter The Player's Last Name : " ;
cin >> search ;
found=linsearch(search);
if (found== 1)
{
cout << "\n There is no player called " << search ;
}
else
{
cout << "\n First Name : " << player[found].getFirstName() << "\n" << "Last Name : " << player[found].getLastName() <<
"\n" << "Age : " << player[found].getAge() << "\n" << "Current Team : " << player[found].getCurrentTeam() <<
"\n" << "Position : " << player[found].getPosition() << "\n" << "Status : " << player[found].getStatus() << "\n\n";
}
cin.get() ;
menu() ;
}
答案 0 :(得分:0)
如果您的数据集可以变大,哈希表就是一个可以想到的解决方案。务必选择一个散列算法,该算法对您的任务没有太多冲突。顺便说一句,有“perfect hashing algorithms” - 如果“0碰撞始终”很重要,你应该看一下 - 无碰撞,快速哈希表会显着加速事情
答案 1 :(得分:0)
将密钥(如用户名称)映射到某种记录的标准解决方案是map
。
股票std::map
使用平衡树,它提供O(log N)搜索,这通常足够好(并且比线性更好),并且还允许您按排序顺序遍历名称。这需要一个有序的类型,这意味着user1 < user2
是有道理的。
或者,std::unordered_map
使用哈希表,它为您提供O(1)搜索,但没有任何排序。这需要一个可混合类型,这意味着hash(user1)
是有意义的。它还需要C ++ 11或C ++ 03实现,它将其作为tr1
或boost
的一部分。
哪一个适合取决于你的需求 - 但通常,它们都很好,而且只是你是否有自然排序或自然哈希函数。
除了比vector
,list
或其他需要线性搜索的集合更有效地从中间搜索和删除之外,它也更简单,更自然。例如,比较这两个:
user find_by_name(vector<user> users, string name) {
return find_if(users.begin(), users.end(), [](auto it) { it->name == name; });
}
user find_by_name(map<string, user> users, string name) {
return map.find(name);
}
(而且,如果你没有C ++ 11 lambdas,那么find_if
会更糟。)
至于“线性搜索......是否足够有效”,这实际上取决于集合的大小。如果您通过100个用户每隔几秒钟进行1次搜索,那么几乎任何事情都足够有效。如果您通过数百万用户进行数千次搜索,则可能不是。如果你不太了解估计,那就试试吧。分析几乎总是任何优化问题的第一步。但是,在这种情况下,假设map
或unordered_map
首先比vector
或list
更简单,更容易阅读,更自然,我不会认为你需要打扰它。