Computer >> คอมพิวเตอร์ >  >> การเขียนโปรแกรม >> C++

ค้นหาโหนดสุดท้ายที่สองของรายการที่เชื่อมโยงในการข้ามผ่านครั้งเดียวใน C++


ตอนนี้เราจะมาดูวิธีรับองค์ประกอบสุดท้ายที่สองในรายการที่เชื่อมโยง สมมติว่ามีองค์ประกอบไม่กี่อย่าง เช่น [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