c++ - 我被困在如何使用 C++ 中一个人的名字和姓氏在双向链表中进行排序算法
问题描述
所以我制作了一个双向链表,其中存储了一个人的名字、姓氏、地址和年龄,而我目前正坚持为列表制作排序算法。到目前为止,我已经设法创建了 3 个函数,一个将节点添加到列表中,一个从列表中删除一个节点,一个用于打印列表。这是我到目前为止所拥有的结构:
struct Node {
string First_Name;
string Last_Name;
string Address;
int age;
Node* next;
Node* prev;
} *first = 0, * last = 0;
addToList 函数:
void addToList()
{
string temp = "Yes";
string First_Name;
string Last_Name;
string Address;
int age;
Node* current = first;
while (temp == "Yes") {
cout << "Enter the persons first name: ";
cin >> First_Name;
cout << "Enter the persons last name: ";
cin >> Last_Name;
cout << "Enter the persons age: ";
cin >> age;
cout << "Enter the persons address: ";
cin >> Address;
cout << "Would you like to add another person? Yes or No";
cin >> temp;
current = new Node;
current->First_Name = First_Name;
current->Last_Name = Last_Name;
current->age = age;
current->Address = Address;
if (last) last->next = current;
else first = current;
current->prev = last;
current->next = 0;
last = current;
}
return;
}
和打印清单:
void printList()
{
if (!first)
{
cout << "Nothing is present in the list." << endl;
return;
}
Node* current = first;
while (current)
{
cout << current->First_Name << " " << current->Last_Name << " " << current->age << " " << current->Address << endl;
current = current->next;
}
}
我的问题是,我如何才能按字母顺序对列表进行排序,我以前从未进行过排序......谢谢!
解决方案
要对双向链表使用自定义排序,请重载operator<
:
struct Person
{
std::string first;
std::string last;
std::string address;
unsigned int age;
bool operator<(const Person& p) const
{
bool is_less_than = false;
if (last == p.last)
{
is_less_than = first < p.first;
}
else
{
is_less_than = last < p.last;
}
return is_less_than;
}
};
现在您可以使用std::list
它,它会自动按姓氏排序,然后是第一个。并且std::list
是一个双向链表。
比较Person
s:
Person a;
Person b;
//...
if (a < b)
{
std::cout << "Person A < Person B\n";
}
推荐阅读
- django - 在 Django 测试中设置标头(API 版本控制)
- excel - Application.FileDialog(msoFileDialogFilePicker) 在 16.0.7726.1049 excel 版本中不起作用
- php - 从 array_rand 函数的结果创建简码
- python-2.7 - 在 Python 中使用 OpenPyXL 包写入数据后如何保持样式格式不变?
- jquery - JQuery:数组和排序
- javascript - 有条件地呈现结束标记以模拟日历行为
- c# - 在意图中提示用户缺少实体并等待他们响应
- http - Dart - HTTP - 使用数组和 int 属性编码 JSON 对象
- html - 背景颜色和标签
- batch-file - 将文件读入数组并写出块