Node.hios
1 #ifndef NODE_H_ 2 #define NODE_H_ 3 class Node 4 { 5 private: 6 int num; 7 char* name; 8 public: 9 Node *next; 10 Node(); 11 Node(const int, const char*); 12 int getNum(); 13 char* getName(); 14 }; 15 16 class List : public Node 17 { 18 private: 19 Node* head; 20 Node* temp1; 21 Node* temp2; 22 Node* tail; 23 public: 24 List(); 25 ~List(); 26 void add(Node &); 27 void remove(Node &); 28 Node* find(Node &); 29 void output(); 30 }; 31 32 #endif
Node.cppspa
1 #define _CRT_SECURE_NO_WARNINGS 2 #include<iostream> 3 #include"Node.h" 4 using namespace std; 5 Node::Node() 6 { 7 num = 0; 8 name = new char[10]; 9 if (!name) 10 { 11 cout << "建立失敗!內存不足!" << endl; 12 exit(1); 13 } 14 strcpy(name, "No name"); 15 next = NULL; 16 } 17 Node::Node(const int a ,const char* b) 18 { 19 num = a; 20 name = new char[strlen(b) + 1]; 21 if (!name) 22 { 23 cout << "建立失敗!內存不足!" << endl; 24 exit(1); 25 } 26 strcpy(name,b); 27 next = NULL; 28 } 29 int Node::getNum() 30 { 31 return num; 32 } 33 char* Node::getName() 34 { 35 return name; 36 } 37 38 39 List::List() 40 { 41 head=NULL; 42 temp1 = NULL; 43 temp2 = NULL; 44 tail = NULL; 45 } 46 47 List::~List() 48 { 49 } 50 51 void List::add(Node & t) 52 { 53 if (head == NULL) 54 { 55 head = new Node(); 56 if (!head) 57 { 58 cout << "建立失敗!內存不足!" << endl; 59 return; 60 } 61 *head = t; 62 temp1 = head; 63 tail = head; 64 } 65 else { 66 temp2 = new Node(); 67 if (!temp2) 68 { 69 cout << "建立失敗!內存不足!" << endl; 70 return; 71 } 72 *temp2 = t; 73 temp1->next = temp2; 74 tail = temp2; 75 temp1 = temp2; 76 } 77 } 78 79 void List::remove(Node &t) 80 { 81 temp1 = head; 82 for (; temp1->getNum() != t.getNum();) 83 { 84 temp2 = temp1; 85 temp1 = temp1->next; 86 if (temp1->next == NULL) 87 { 88 cout << "刪除失敗!未找到節點!" << endl; 89 return; 90 } 91 } 92 if (strcmp(temp1->getName(), t.getName()) == 0) 93 { 94 temp2->next = temp1->next; 95 delete temp1; 96 } 97 else 98 cout << "刪除失敗!學號和姓名不匹配!" << endl; 99 } 100 101 Node* List::find(Node &t) 102 { 103 temp1 = head; 104 for (; temp1->getNum() != t.getNum();) 105 { 106 temp1 = temp1->next; 107 if (temp1->next == NULL) 108 { 109 cout << "查找失敗!未找到節點!" << endl; 110 return NULL; 111 } 112 } 113 if (strcmp(temp1->getName(), t.getName()) == 0) 114 { 115 return temp1; 116 } 117 else 118 cout << "查找失敗!學號和姓名不匹配!" << endl; 119 } 120 121 122 void List::output() 123 { 124 temp1 = head; 125 cout << "Num:" << temp1->getNum() << " Name:" << temp1->getName() << endl; 126 while (1) 127 { 128 temp1 = temp1->next; 129 cout << "Num:" << temp1->getNum() << " Name:" << temp1->getName() << endl; 130 if (temp1->next == NULL) 131 break; 132 } 133 }
mian.cpp操作系統
/* exit(1)表示異常退出.這個1是返回給操做系統的。 exit(x)(x不爲0)都表示異常退出; exit(0)表示正常退出。 */ #include<iostream> #include"Node.h" using namespace std; int main() { List a; Node stu[5] = { Node(101, "Merry") ,Node (102, "Jack") ,Node(103,"Tom"),Node(104,"John"),Node(105,"Mike")}; for (int i = 0; i < 5;++i) a.add(stu[i]); a.output(); cout << "刪除節點" << endl; a.remove(Node(102, "Jack")); a.output(); system("pause"); return 0; }