file:LinkedList.hpp
#ifndef LinkedList_hpp
#define LinkedList_hpp
#include <stdio.h>
#include "Node.hpp"
class LinkedList{
public:
LinkedList();
~LinkedList();
void ClearList();
bool ListEmpty();
int ListLength();
bool getElem(int index,Node *pNode);
int locateElem(Node *pNode);
bool preElem(Node *pCurrentNode,Node *pPreNode);
bool nextElem(Node *pCurrentNode,Node *pNextNode);
void ListTraverse();
bool ListInsert(int index,Node *pNode);
bool ListDelete(int index,Node *pNode);
bool ListInsertHead(Node *pNode);
bool ListInsertTail(Node *pNode);
private:
int m_iLength;
Node *m_pList;
};
#endif /* LinkedList_hpp */
file:LinkedList.cpp
#include "LinkedList.hpp"
#include <iostream>
using namespace std;
LinkedList::LinkedList(){
m_pList = new Node;
m_pList->next = NULL;
m_iLength = 0;
}
bool LinkedList::ListEmpty(){
return m_iLength==0?true:false;
}
int LinkedList::ListLength(){
return m_iLength;
}
void LinkedList::ClearList(){
Node *CurrentNode = m_pList->next;
while(CurrentNode != NULL){
Node *temp = CurrentNode->next;
delete CurrentNode;
CurrentNode = temp;
}
m_pList->next = NULL;
m_iLength = 0;
}
LinkedList::~LinkedList(){
ClearList();
delete m_pList;
m_pList = NULL;
}
bool LinkedList::ListInsertHead(Node *pNode){
Node *temp = m_pList->next;
Node *newNode = new Node;
if(newNode == NULL){
return false;
}
else{
m_pList->next = newNode;
newNode->data = pNode->data;
newNode->next = temp;
m_iLength++;
return true;
}
}
bool LinkedList::ListInsertTail(Node *pNode){
Node *CurrentNode = m_pList;
while(CurrentNode->next != NULL){
CurrentNode = CurrentNode->next;
}
Node *newNode = new Node;
if(newNode == NULL){
return false;
}
else{
CurrentNode->next = newNode;
newNode->data = pNode->data;
newNode->next = NULL;
m_iLength++;
return true;
}
}
bool LinkedList::ListInsert(int index, Node *pNode){
if(index < 0 || index > m_iLength){
return false;
}
else{
Node *CurrentNode = m_pList;
for(int k = 0;k < index;k++){
CurrentNode = CurrentNode->next;
}
Node *newNode = new Node;
if(newNode == NULL){
return false;
}
else{
newNode->data = pNode->data;
newNode->next = CurrentNode->next;
CurrentNode->next = newNode;
m_iLength++;
return true;
}
}
}
bool LinkedList::ListDelete(int index, Node *pNode){
if(index < 0 || index > m_iLength){
return false;
}
else{
Node *CurrentNode = m_pList;
Node *CurrentNodePre = NULL;
for(int k = 0;k < index;k++){
CurrentNodePre = CurrentNode;
CurrentNode = CurrentNode->next;
}
CurrentNodePre->next = CurrentNode->next;
pNode->data = CurrentNode->data;
delete CurrentNode;
CurrentNode = NULL;
m_iLength--;
return true;
}
}
bool LinkedList::getElem(int index,Node *pNode){
if(index < 0 || index > m_iLength){
return false;
}
else{
Node *CurrentNode = m_pList;
Node *CurrentNodePre = NULL;
for(int k = 0;k < index;k++){
CurrentNodePre = CurrentNode;
CurrentNode = CurrentNode->next;
}
pNode->data = CurrentNode->data;
return true;
}
}
int LinkedList::locateElem(Node *pNode){
Node *CurrentNode = new Node;
int count = 0;
while(CurrentNode->next != NULL){
CurrentNode = CurrentNode->next;
if(CurrentNode->data == pNode->data){
return count;
}
else{
count ++;
}
}
return -1;
}
bool LinkedList::preElem(Node *pCurrentNode,Node *pPreNode){
Node *CurrentNode = m_pList;
Node *tempNode = NULL;
while(CurrentNode->next != NULL){
tempNode = CurrentNode;
CurrentNode = CurrentNode->next;
if(CurrentNode->data == pCurrentNode->data){
if(tempNode == m_pList){
return false;
}
else{
pPreNode->data = tempNode->data;
return true;
}
}
}
return false;
}
bool LinkedList::nextElem(Node *pCurrentNode,Node *pNextNode){
Node *CurrentNode = m_pList;
while(CurrentNode->next != NULL){
CurrentNode = CurrentNode->next;
if(CurrentNode->data == pCurrentNode->data){
if(CurrentNode->next == NULL ){
return false;
}
else{
pNextNode->data = CurrentNode->next->data;
return true;
}
}
}
return false;
}
void LinkedList::ListTraverse(){
Node *CurrentNode = m_pList;
while(CurrentNode->next != NULL){
CurrentNode = CurrentNode->next;
CurrentNode->printData();
}
cout << endl;
}
file:Node.hpp
#ifndef Node_hpp
#define Node_hpp
#include "Person.hpp"
class Node{
public:
void printData();
public:
Person data;
Node *next;
Node *prev;
};
#endif /* Node_hpp */
file:Node.cpp
#include "Node.hpp"
#include <iostream>
using namespace std;
void Node::printData(){
cout << data << endl;
}
file:Person.hpp
#ifndef Person_hpp
#define Person_hpp
#include <stdio.h>
#include <string>
using namespace std;
class Person{
public:
friend ostream &operator<<(ostream &out,Person &person);
string name;
string phone;
Person &operator=(Person &person);
bool operator==(Person &person);
};
#endif /* Person_hpp */
file:Person.cpp
#include "Person.hpp"
#include <ostream>
ostream &operator<<(ostream &out,Person &person){
out << person.name << "------------" << person.phone << endl;
return out;
}
Person &Person::operator=(Person &person){
this->name = person.name;
this->phone = person.phone;
return *this;
}
bool Person::operator==(Person &person){
if(this->name == person.name && this->phone == person.phone){
return true;
}
else{
return false;
}
}
file:demo.cpp
#include <iostream>
#include <string>
#include "LinkedList.hpp"
using namespace std;
int main(void){
Node node1;
node1.data.name = "James";
node1.data.phone = "123456789";
Node node2;
node2.data.name = "Jobs";
node2.data.phone = "987654321";
LinkedList *pList = new LinkedList;
pList->ListInsertTail(&node1);
pList->ListInsertTail(&node2);
pList->ListTraverse();
delete pList;
pList = NULL;
}
打开App,阅读手记