I have a custom class ‘team’ and one of its attributes is its ‘name.’ After each ‘team’ is created, I add it to a vector teamList.
I would like to implement a function that continuously prompts the user for a team name which is not already taken by a team within the teamList. I have the following code:
while (true) {
string newString;
bool flag = true;
getline(cin, newString);
for (int i = 0; i < teamList.size(); i++) {
if (teamList[i].name.compare(newString) == 0) flag = false;
}
if (flag == true) {
return newString;
} else {
cout << "name already taken." << endl;
}
}
However, this code is really ugly; is there a better way to check? Also, a more general question- faced with an issue of ugly code (like this one), what kinds of steps can I take to find a new, cleaner implementation? Thanks.
I would use
std::set, which deals with duplicates for you. As an example, you can see that the class is sorted by the string member, and when three are inserted inmain, only two stay because two of the insertions have the same string, so they are treated equal.Now for inserting, you can just reprompt while the
secondmember of the returned pair isfalse: