이 C++ 코드에서 연결된 목록이 어떻게 작동하는지 이해해야합니다. 내 교과서에서 가져 왔어. 정확히 여기서 무슨 일이 일어나는지 자세히 설명해 줄 수 있습니까?연결된 목록 설명 필요
/*The Node Class*/
class Node{
private:
int object;
Node *nextNode;
public:
int get()
{
return object;
}
void set(int object)
{
this-> object=object;
}
Node *getNext()
{
return nextNode;
};
void setNext(Node *nextNode)
{
this->nextNode = nextNode;
};
};
/* The List class */
class List
{
public:
List();
void add (int addObject);
int get();
bool next();
friend void traverse(List list);
friend List addNodes();
private:
int size;
Node * headNode;
Node * currentNode;
Node * lastCurrentNode;
};
/* Constructor */
List::List()
{
headNode = new Node();
headNode->setNext(NULL);
currentNode = NULL;
lastCurrentNode = NULL;
size = 0;
}
/* add() class method */
void List::add (int addObject)
{
Node * newNode = new Node();
newNode->set(addObject);
if(currentNode != NULL)
{
newNode->setNext(currentNode->getNext());
currentNode->setNext(newNode);
lastCurrentNode = currentNode;
currentNode = newNode;
}
else
{
newNode->setNext(NULL);
headNode->setNext(newNode);
lastCurrentNode = headNode;
currentNode = newNode;
}
size ++;
}
/* get() class method */
int List::get()
{
if (currentNode != NULL)
return currentNode->get();
}
/* next() class method */
bool List::next()
{
if (currentNode == NULL) return false;
lastCurrentNode = currentNode;
currentNode = currentNode->getNext();
if (currentNode == NULL || size == 0)
return false;
else
return true;
}
/* Friend function to traverse linked list */
void traverse(List list)
{
Node* savedCurrentNode = list.currentNode;
list.currentNode = list.headNode;
for(int i = 1; list.next(); i++)
{
cout<<"\n Element "<<i<<" "<<list.get();
}
list.currentNode = savedCurrentNode;
}
/* Friend function to add Nodes into the list */
List addNodes()
{
List list;
list.add(2);
list.add(8);
list.add(7);
list.add(1);
cout<<"\n List size = "<<list.size<<"\n";
return list;
}
main()
{
List list = addNodes();
traverse(list);
system("pause");
}
Q의 트랙 레코드에 도움을 얻는 데 문제가 있습니다 링크드리스트의 작동 원리를 설명하는 온라인 리소스가 많이 있습니다. – wheaties
텍스트 북에서이 코드를 얻었지만 텍스트 북은 어떻게 작동하는지 설명하지 않습니다. 위키 백과의 링크 된 목록은 다음과 같습니다. http://en.wikipedia.org/wiki/Linked_list –
위의 구현에서 이해할 수없는 특정 부분을 선택할 수있는 경우 도움이 될 수 있습니다. 그것이 가능할 것이라고 생각합니다. –