鏈表的倒序輸出

鏈表的倒序輸出,我們可能想到的方法就是把鏈表翻轉後然後再遍歷一遍,這樣的話時間複雜度是O(n),但是缺點是代碼稍微複雜。或者是開闢一個數組,順序遍歷一個鏈表把元素複製到數組裏面,最後再把數組倒序輸出。其實這道題目時間複雜度都不可能低於O(n),但是考慮用棧的話代碼就可能非常簡單,代碼如下所示:

#include <iostream>
using namespace std;

struct Node
{
	int key;
	Node* next;
};

Node* createList(int arr[],int nLength);
void printList(Node* head);
void reversePrint(Node* head);
void clearList(Node* head);

void main()
{
	int arr[] = {1,3,5,7,9};
	int nLength = sizeof(arr)/sizeof(arr[0]);
	Node* head = createList(arr,nLength);
	printList(head);
	reversePrint(head);
	clearList(head);
}

Node* createList(int arr[],int nLength)
{
	Node* head = new Node;
	head->key = arr[0];
	head->next = NULL;
	Node *p = head;
	for(int i=1;i<nLength;i++)
	{
		Node* ptr = new Node;
		ptr->key = arr[i];
		ptr->next = NULL;
		p->next = ptr;
		p = p->next;
	}
	return head;
}


void printList(Node* head)
{
	Node* p = head;
	while( p!= NULL )
	{
		cout<<p->key<<endl;
		p=p->next;
	}
}

void clearList(Node* head)
{
	Node* p = head;
	Node* ptr;
	while( p!= NULL )
	{
		ptr = p->next;
		delete p;
		p = ptr;
	}
}

void reversePrint(Node* head)
{
	if( head != NULL )
	{
		if( head->next != NULL )
			reversePrint(head->next);
	}
	cout<<head->key<<endl;
}


發佈了212 篇原創文章 · 獲贊 34 · 訪問量 42萬+
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章