<算法编程> 从尾到头打印链表

  1 #include<iostream>
  2 using namespace std;
  3 
  4 struct Node
  5 {
  6     int n;
  7     Node* pNext;
  8 };
  9 
 10 Node* AddNode(Node** pHead,Node* pNode)
 11 {
 12     if((*pHead) == NULL)
 13     {
 14         (*pHead) = pNode;
 15     }
 16     else 
 17     {
 18         Node* pEnd = (*pHead);
 19         while(pEnd->pNext != NULL)
 20         {
 21             pEnd = pEnd->pNext;
 22         }
 23         pEnd->pNext = pNode;
 24     }
 25 
 26     return *pHead;
 27 }
 28 
 29 void PrintList(Node* pHead)
 30 {
 31     while(pHead)
 32     {
 33         cout << pHead->n << " ";
 34         pHead = pHead->pNext;
 35     }
 36     cout << endl;
 37 }
 38 
 39 //递归方式
 40 void pfun(Node* pHead)
 41 {
 42     if(pHead == NULL) return ;
 43     
 44     Node* pNode = pHead;
 45     if(pNode != NULL)
 46     {
 47         if(pNode->pNext != NULL)
 48             pfun(pNode->pNext);
 49         cout << pNode->n << endl;
 50     }
 51 
 52     return ;
 53 }
 54 
 55 //数组方式:开辟一个和链表一样长度的数组 遍历一遍链表存进数组
 56 //然后数组倒着输出就可以了
 57 
 58 //栈:利用栈先进后出的方式来打印
 59 //遍历一个链表就压一个进栈
 60 //最后全部弹出打印
 61 
 62 int main()
 63 {
 64     Node* pHead = NULL;
 65 
 66     Node* pNode1 = new Node;
 67     pNode1->n = 1;
 68     pNode1->pNext = NULL;
 69     AddNode(&pHead,pNode1);
 70     Node* pNode2 = new Node;
 71     pNode2->n = 2;
 72     pNode2->pNext = NULL;
 73     AddNode(&pHead,pNode2);
 74     Node* pNode3 = new Node;
 75     pNode3->n = 3;
 76     pNode3->pNext = NULL;
 77     AddNode(&pHead,pNode3);
 78     Node* pNode4 = new Node;
 79     pNode4->n = 4;
 80     pNode4->pNext = NULL;
 81     AddNode(&pHead,pNode4);
 82     Node* pNode5 = new Node;
 83     pNode5->n = 5;
 84     pNode5->pNext = NULL;
 85     AddNode(&pHead,pNode5);
 86     Node* pNode6 = new Node;
 87     pNode6->n = 6;
 88     pNode6->pNext = NULL;
 89     AddNode(&pHead,pNode6);
 90     Node* pNode7 = new Node;
 91     pNode7->n = 7;
 92     pNode7->pNext = NULL;
 93     AddNode(&pHead,pNode7);
 94     Node* pNode8 = new Node;
 95     pNode8->n = 8;
 96     pNode8->pNext = NULL;
 97     AddNode(&pHead,pNode8);
 98     
 99     pfun(pHead);
100 
101     system("pause");
102     return 0;
103 }

 

posted @ 2019-07-20 18:53  Aaaaaalei  阅读(115)  评论(0编辑  收藏  举报