现在,我们将看到如何获取链表中的倒数第二个元素。假设元素很少,例如[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