亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? 8_2.cpp

?? 這是一個雙向鏈表的問題
?? CPP
字號:
/*第2題	雙向鏈表--源代碼及關鍵源代碼注解如下:*/
// Author : Vinayak Marwah 

#include <iostream.h>
#include <conio.h>
#include "Double Link List.h"

void main()
{
	DoubleLinkList< int > List;
	int Value = 0 ,Option = 0;
	do
	{
		cout<<"\n\t\t Driver To Test  Link List "
			<<"\n\t\t\t\t Menu ."
			<<"\n\t\t\t\t______ "
			<<"\n 1.) Insert At Front Of A Double Linked List . "
			<<"\n 2.) Insert At Rear Of A Double Linked List . "
			<<"\n 3.) Insert In Middle Of A Double Linked List . "
			<<"\n 4.) Remove From Front Of A Double Linked List. "
			<<"\n 5.) Remove From Rear Of A Double Linked List. "
			<<"\n 6.) Remove From Middle Of The Double Linked List . "
			<<"\n 7.) Traverse Forward A Double Linked List ."
			<<"\n 8.) Traverse Backwards A Double Linked List . "
			<<"\n 9.) Lenght Of The Double Linked List ."
			<<"\n 10.) End Double Linked List Processing & Exit . "
			<<"\n     Enter Your Choice : \t";
		cin>>Option;
		switch(Option)
			{
			case 1 :
				{
					cout<<"\n Enter Data : ";
					cin>>Value;
					List.InsertAtFront(Value);
					break;
				}
			case 2 :
				{
					cout<<"\n Enter Data : ";
					cin>>Value;
					List.InsertAtRear(Value);
					break;
				}
			case 3:
				{
					cout<<"\n Enter Data : ";
					cin>>Value;
					List.InsertAtMiddle(Value);
					break;
				}
			case 4 :
				{
					List.RemoveFromFront();
					break;
				}
			case 5 :
				{
					List.RemoveFromRear();
					break;
				}
			case 6:
				{
					List.RemoveFromMiddle();
					break;
				}

			case 7 :
				{
					List.TraverseForward();
					break;
				}
			case 8 :
				{
					List.TraverseBackwards();
					break;
				}
			case 9 :
				{
					cout<<"\n The Lenght Of A Double Linked List "
						<<"\n (ie Number Of Nodes In A Double Linked List ) : "
						<<List.LenghtOfDoubleLinkList();
					break;
				}
			case 10 :
				{
					break;
				}
			default :
				{
					Option = 10;
					break;
				}
			}
		}
	while( Option != 10 );
}

#include <iostream.h>
#include <conio.h>
#include <assert.h>
#include "Double Link List.H"
template< class NodeType >
Node< NodeType >::Node()
:Data( NULL ),NextNode( NULL ),PreviousNode( NULL ) {}
/**********************************************************************/
template< class NodeType >
Node< NodeType >::Node( NodeType &Value )
:Data( Value ),NextNode( NULL ),PreviousNode( NULL ) 
{
	cout<<"\n A Node Created Successfully . ";
}
/**********************************************************************/
template< class NodeType >
Node< NodeType >::~Node()
{
	cout<<"\n A Node Destroyed Successfully .";
}
/**********************************************************************/
template< class NodeType >
DoubleLinkList< NodeType >::DoubleLinkList()
:FirstNode( NULL ),RearNode( NULL )
{
	cout<<"\n A Double Linked List Created Successfully .";
}

/**********************************************************************/

template< class NodeType >
DoubleLinkList< NodeType >::~DoubleLinkList()
{
	cout<<"\n Mission : Destroy A Double Linked List . \n";
	Node< NodeType > *CurrentNode = FirstNode, *TempNode ;
	while( CurrentNode != NULL )
		{
		TempNode = CurrentNode;
		CurrentNode = CurrentNode->NextNode;
		cout<<TempNode->Data<<" , ";
		delete TempNode;
		}
	cout<<"\n Status : Mission Successfull . "
		<<"\n A Double Linked List Destroyed Successfully ."
		<<"\n Press Any Key To Continue ";
	getch();
}
/**********************************************************************/
template< class NodeType >
bool DoubleLinkList< NodeType >::IsEmpty()
{
	if( FirstNode == NULL )
		{
		cout<<"\n No Double Linked List Exists . ";
		return true;
		}
	else
		return false;
}
/**********************************************************************/
template< class NodeType >
Node< NodeType > *DoubleLinkList< NodeType >::CreateNode( NodeType &Value )
{
	Node< NodeType > *NewNode = new Node< NodeType >( Value );
	assert( NewNode != NULL );
	return NewNode ;
}
/**********************************************************************/
template< class NodeType >
void DoubleLinkList< NodeType >::InsertAtFront( NodeType &Value )
{
	cout<<"\n Mission : Insertion Of A Node At The Front Of The Linked List .\n";
	Node< NodeType > *NewNode = CreateNode(Value);
	if ( IsEmpty() )
		{
		cout<<"\n Mission : Generating A New Double Link List . ";
		FirstNode = RearNode = NewNode ;
		}
	else
		{
		FirstNode->PreviousNode = NewNode;
		NewNode->NextNode = FirstNode;
		FirstNode = NewNode;
		FirstNode->PreviousNode = NULL;
		}
	cout<<FirstNode->Data;
	cout<<"\n Status : Mission SuccessFull ."
		<<"\n Node Inserted At Front SuccessFully . "
		<<"\n Press Any Key To Continue . ";
	getch();
}
/**********************************************************************/
template< class NodeType >
void DoubleLinkList< NodeType >::InsertAtMiddle( NodeType &Value )
{
	cout<<"\n Operation : Insertion Of A Node In The Middle Of The Linked List .\n";
	Node< NodeType > *NewNode = CreateNode(Value);
	if ( IsEmpty() )
		{
		cout<<"\n Mission : Generating A New Double Link List . ";
		FirstNode = RearNode = NewNode ;
		}
	else
		{
		Node< NodeType > *CurrentNode = FirstNode,*TempNode;
		int Middle = (LenghtOfDoubleLinkList()/2),Position = 0;
		while( Position != Middle )
			{
			CurrentNode = CurrentNode->NextNode;
			Position++;
			}
		TempNode = CurrentNode;
		NewNode->PreviousNode = CurrentNode->PreviousNode;
		NewNode->NextNode = CurrentNode;
		CurrentNode = CurrentNode->PreviousNode;
		CurrentNode->NextNode = NewNode ;
		TempNode->PreviousNode = NewNode;
		}
	cout<<NewNode->Data;
	cout<<"\n Status : Mission SuccessFull ."
		<<"\n Node Inserted In Middle SuccessFully . "
		<<"\n Press Any Key To Continue . ";
	getch();
}
/**********************************************************************/
template< class NodeType >
void DoubleLinkList< NodeType >::InsertAtRear( NodeType &Value )
{
	cout<<"\n Operation : Insertion Of A Node At The End Of The Linked List .\n";
	Node< NodeType > *NewNode = CreateNode(Value);
	if ( IsEmpty() )
		{
		cout<<"\n Mission : Generating A New Double Link List . ";
		FirstNode = RearNode = NewNode ;
		}
	else
		{
		NewNode->PreviousNode = RearNode;
		RearNode->NextNode = NewNode;
		RearNode = NewNode;
		RearNode->NextNode = NULL;
		}
	cout<<RearNode->Data;
	cout<<"\n Status : Mission SuccessFull ."
		<<"\n Node Inserted At Rear SuccessFully . "
		<<"\n Press Any Key To Continue . ";
	getch();
}
/**********************************************************************/
template< class NodeType >
bool DoubleLinkList< NodeType >::RemoveFromFront()
{
	cout<<"\n Operation : Removal Of A Node From Front Of A Double Linked List .\n";
	if( IsEmpty() )
		{
		cout<<"\n Invalid Operation ."
			<<"\n Status : Mission Failed . "
			<<"\n Press Any Key To Continue . ";
		getch();
		return false;
		}
	else
		{
		Node< NodeType > *CurrentNode = FirstNode;
		if( FirstNode == RearNode )
			FirstNode = RearNode = NULL;
		else
			{
			cout<<"\n Data In The First Node Is : ";
			cout<<CurrentNode->Data;
			FirstNode = FirstNode->NextNode;
			FirstNode->PreviousNode = NULL ;
			}
		delete CurrentNode;
		cout<<"\n Status : Mission SuccessFull ."
			<<"\n Node Removed From Front Of The Doubled Linked List Successfully ";
		return true;
		}
		cout<<"\n Press Any Key To Continue . ";
		getch();
}
/**********************************************************************/
template< class NodeType >
bool DoubleLinkList< NodeType >::RemoveFromMiddle()
{
	cout<<"\n Operation : Insertion Of A Node In The Middle Of The Linked List .\n";
	if( IsEmpty() )
		{
		cout<<"\n Invalid Operation ."
			<<"\n Status : Mission Failed . "
			<<"\n Press Any Key To Continue . ";
		getch();

		return false;
		}
	else
		{
		Node< NodeType > *CurrentNode = FirstNode,*TempNode,*TEmpNode;
		int Middle = (LenghtOfDoubleLinkList()/2),Position = 0;
		while( Position != Middle )
			{
			CurrentNode = CurrentNode->NextNode;
			Position++;
			}
		TempNode = CurrentNode ;
		CurrentNode = CurrentNode->NextNode ;
		CurrentNode->PreviousNode = TempNode->PreviousNode ;
		TEmpNode = TempNode->PreviousNode ;
		TEmpNode->NextNode = CurrentNode ;
		cout<<TempNode->Data;
		delete TempNode;
		}
	cout<<"\n Status : Mission SuccessFull ."
		<<"\n Node Removed From Middle SuccessFully . "
		<<"\n Press Any Key To Continue . ";
	getch();
	return true;
}
/**********************************************************************/
template< class NodeType >
bool DoubleLinkList< NodeType >::RemoveFromRear()
{
	cout<<"\n Operation : Removal Of A Node From Rear Of A Double Linked List .\n";
	if( IsEmpty() )
		{
		cout<<"\n Invalid Operation ."
			<<"\n Status : Mission Failed . "
			<<"\n Press Any Key To Continue . ";
		getch();

		return false;
		}
	else
		{
		Node< NodeType > *TempNode = RearNode;
		if( FirstNode == RearNode )
			FirstNode = RearNode = NULL;
		else
			RearNode = RearNode->PreviousNode;
		RearNode->NextNode = NULL;
		cout<<TempNode->Data;
		delete TempNode;
		cout<<"\n Status : Mission SuccessFull ."
			<<"\n Node Removed From Rear Of The Double Linked List Successfully  .";
		return true;
		}
		cout<<"\n Press Any Key To Continue . ";
		getch();
}
/**********************************************************************/
template< class NodeType >
void DoubleLinkList< NodeType >::TraverseForward()
{
	Node< NodeType > *CurrentNode = FirstNode ;
	cout<<"\n Mission : Traversing & Printing A Double Linked List ."
		<<"\n           In Forward Direction ."
		<<"\n The Double Linked List Follows : \n";
	while ( CurrentNode != NULL)
		{
		cout<<CurrentNode->Data<<" , ";
		CurrentNode = CurrentNode->NextNode;
		}
	cout<<"\n Status : Operation Successfull ."
		<<"\n Traversed & Printed Double Linked List Successfully . "
		<<"\n Press Any Key To Continue .";
	getch();
}
/**********************************************************************/
template< class NodeType >
void DoubleLinkList< NodeType >::TraverseBackwards()
{
	Node< NodeType > *CurrentNode = RearNode ;
	cout<<"\n Mission : Traversing & Printing A Double Linked List ."
		<<"\n           In Backward Direction "
		<<"\n The Double Linked List Follows : \n";
	while ( CurrentNode != NULL)
		{
		cout<<CurrentNode->Data<<" , ";
		CurrentNode = CurrentNode->PreviousNode;
		}
	cout<<"\n Status : Operation Successfull ."
		<<"\n Traversed & Printed Double Linked List Successfully . "
		<<"\n Press Any Key To Continue .";
	getch();
}
/**********************************************************************/
template< class NodeType >
int DoubleLinkList< NodeType >::LenghtOfDoubleLinkList()
{
	int NosOfNodes = 0 ;
	Node< NodeType > *CurrentNode = FirstNode ;
cout<<"\n Mission : Traverse & Calculate The Number Of Nodes In A Double Linked List ."<<"\n The Double Linked List Follows : \n";
	while ( CurrentNode != NULL)
		{
		NosOfNodes++;
		CurrentNode = CurrentNode->NextNode;
		}
	cout<<"\n Status : Operation Successfull ."
<<"\n Traversed & Calculated Number Of Nodes In A Double Linked List Successfully . "<<"\n Press Any Key To Continue .";
	getch();
	return NosOfNodes;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
青青草国产成人99久久| 香蕉影视欧美成人| 欧美日韩一区中文字幕| 精彩视频一区二区三区| 亚洲欧美综合色| 日韩美女视频一区二区在线观看| 不卡av在线免费观看| 日韩不卡在线观看日韩不卡视频| 国产嫩草影院久久久久| 91麻豆精品国产91久久久资源速度| 国产成a人无v码亚洲福利| 日日夜夜一区二区| 亚洲欧美偷拍另类a∨色屁股| 26uuu国产电影一区二区| 欧美性视频一区二区三区| 91精品国产入口| 91天堂素人约啪| 国产精品一区二区在线观看网站| 亚洲1区2区3区视频| 亚洲少妇中出一区| 日本一区二区动态图| 精品国产a毛片| 日韩午夜小视频| 精品视频色一区| 欧美中文字幕一区| 91网页版在线| 91网站最新网址| eeuss鲁片一区二区三区在线看| 国产中文字幕一区| 久久99精品久久只有精品| 日韩精品一二三四| 丝袜诱惑制服诱惑色一区在线观看| 亚洲黄网站在线观看| 亚洲欧美中日韩| 亚洲色图.com| 亚洲视频一区二区免费在线观看| 国产精品大尺度| 中文字幕在线不卡国产视频| 欧美国产一区二区| 国产蜜臀97一区二区三区 | 国产福利一区二区三区在线视频| 麻豆专区一区二区三区四区五区| 日韩av电影天堂| 久久国产三级精品| 精久久久久久久久久久| 国产美女av一区二区三区| 国产精品综合在线视频| 国产成人av福利| 99久久99精品久久久久久| 99久久国产综合色|国产精品| 久久久久久久久一| 久久中文字幕电影| 国产网红主播福利一区二区| 国产欧美日韩在线视频| 中文乱码免费一区二区| 中文字幕一区在线观看视频| 亚洲三级在线免费观看| 一区二区三区精品| 日韩专区一卡二卡| 国内外成人在线| 岛国av在线一区| 色婷婷av一区二区三区大白胸| 欧美性猛交xxxxxxxx| 91麻豆精品国产综合久久久久久| 欧美mv日韩mv国产网站app| 久久综合狠狠综合久久激情 | 日韩精品一区二区三区老鸭窝| 久久看人人爽人人| 亚洲欧洲性图库| 日韩—二三区免费观看av| 国内欧美视频一区二区| 99热99精品| 91精品国产91热久久久做人人| 久久久欧美精品sm网站| 亚洲欧美日韩精品久久久久| 日韩精品亚洲专区| 丁香婷婷深情五月亚洲| 欧美少妇xxx| 久久九九国产精品| 一区二区三区 在线观看视频| 免费在线看一区| 成人国产在线观看| 91麻豆精品国产91久久久久| 国产精品三级久久久久三级| 午夜视频在线观看一区二区| 国产乱人伦偷精品视频免下载| 91蝌蚪porny| 精品久久久久一区| 亚洲精品乱码久久久久| 精品一区二区三区免费观看| 99国产欧美另类久久久精品| 欧美一区二区三区视频| 国产精品激情偷乱一区二区∴| 日韩av在线发布| 91麻豆福利精品推荐| 精品国产一区二区三区av性色| 亚洲精品成人在线| 国产成人免费在线观看不卡| 欧美久久一二三四区| 日韩一区日韩二区| 久久不见久久见免费视频1| 91搞黄在线观看| 国产亚洲综合av| 蜜桃视频一区二区三区| 在线观看亚洲专区| 国产精品水嫩水嫩| 精品一区二区三区免费毛片爱| 欧美精品九九99久久| 亚洲丝袜另类动漫二区| 国产一区二区久久| 制服.丝袜.亚洲.中文.综合| 亚洲欧美色图小说| 懂色中文一区二区在线播放| 精品国产露脸精彩对白| 三级欧美在线一区| 欧美日韩一区二区三区高清| 亚洲天堂精品在线观看| 成人av在线资源| 久久久777精品电影网影网| 免费久久99精品国产| 欧美视频一区在线观看| 一区二区在线电影| 99re亚洲国产精品| 国产精品色呦呦| 成人小视频在线观看| 久久精品水蜜桃av综合天堂| 激情综合色播激情啊| 日韩午夜av一区| 毛片不卡一区二区| 欧美一三区三区四区免费在线看 | 亚洲最新视频在线观看| 色欧美乱欧美15图片| 亚洲精品成人精品456| 99久久精品99国产精品| 日韩毛片在线免费观看| 91亚洲国产成人精品一区二三| 综合久久国产九一剧情麻豆| 成人91在线观看| 亚洲另类一区二区| 欧美经典三级视频一区二区三区| 国产激情91久久精品导航 | 亚洲国产日韩综合久久精品| 在线观看视频一区| 亚洲一区二区精品视频| 欧美少妇xxx| 蜜臀va亚洲va欧美va天堂| 日韩丝袜美女视频| 激情五月播播久久久精品| 国产亚洲精品久| 99热精品一区二区| 一区二区日韩av| 91精品国产一区二区人妖| 久久99国产精品尤物| 久久九九全国免费| 99久久er热在这里只有精品66| 亚洲精品你懂的| 欧美群妇大交群中文字幕| 美女www一区二区| 欧美国产一区在线| 欧洲精品中文字幕| 日本v片在线高清不卡在线观看| 精品国产乱码久久久久久1区2区 | 国产亚洲一本大道中文在线| 成人爽a毛片一区二区免费| 亚洲欧美日韩国产综合在线| 欧美日本一区二区| 激情欧美一区二区| 国产精品美女视频| 欧美日韩综合一区| 激情欧美一区二区| 又紧又大又爽精品一区二区| 日韩一区二区免费视频| 丁香桃色午夜亚洲一区二区三区| 亚洲精品中文字幕在线观看| 日韩一级免费一区| 福利一区二区在线观看| 亚洲一区二区欧美日韩 | 亚洲成人激情社区| 久久青草国产手机看片福利盒子 | 9191国产精品| 成人性生交大合| 青青草原综合久久大伊人精品 | 婷婷亚洲久悠悠色悠在线播放 | 国产精品福利一区二区| 717成人午夜免费福利电影| 国产成人午夜高潮毛片| 亚洲一区二区三区小说| 久久久综合九色合综国产精品| 色国产综合视频| 国产精品夜夜嗨| 亚洲综合一区二区精品导航| 欧美成人高清电影在线| 91麻豆.com| 国产大片一区二区| 在线观看一区日韩| 国产一区二区在线影院| 偷拍亚洲欧洲综合| 亚洲免费av观看| 亚洲国产激情av| 欧美v日韩v国产v|