现在,我们将看到如何获取链表中的倒数第二个元素。假设元素很少,例如[10、52、41、32、69、58、41],倒数第二个元素是58。
为了解决这个问题,我们将使用两个指针,一个指针指向当前节点,另一个指针指向当前位置的上一个节点,然后我们将移动直到当前下一个为空,然后简单地返回上一个节点。
#include<iostream> using namespace std; class Node { public: int data; Node *next; }; void prepend(Node** start, int new_data) { Node* new_node = new Node; new_node->data = new_data; new_node->next = NULL; if ((*start) != NULL){ new_node->next = (*start); *start = new_node; } (*start) = new_node; } int secondLastElement(Node *start) { Node *curr = start, *prev = NULL; while(curr->next != NULL){ prev = curr; curr = curr->next; } return prev->data; } int main() { Node* start = NULL; prepend(&start, 15); prepend(&start, 20); prepend(&start, 10); prepend(&start, 9); prepend(&start, 7); prepend(&start, 17); cout << "Second last element is: " << secondLastElement(start); }
输出结果
Second last element is: 20