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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? listutilities1.c

?? 通訊錄程序源代碼 來源:cprogramming 作者:Hammer
?? C
字號:
#include "main.h"/*  =============================================================================== 	Author:		Hammer, May 2002, For www.cprogramming.com/cboard/ 	File:		ListUtilities.c 	Contents:	li_Create 				nd_Create 				nd_Destroy 				li_Traverse 				li_Insert 				li_Destroy 				li_GetDataPtrByID 				li_DeleteNodeAndData 				li_Count  ===============================================================================*//*  ===============================================================================    Function: 	li_Create    Args: 		None    Returns: 	NULL pointer.    Purpose:	Dummy function to start off a list.  =============================================================================== */struct Node *li_Create(void){	return (NULL);} /*  ===============================================================================    Function: 	nd_Create    Args: 		A void ptr to the data to be referenced (A record).    Returns: 	Pointer to new node, ready for insertion into the tree.    			NULL if malloc fails    Purpose:	Creates a single node, containing a pointer to some data (Record)  =============================================================================== */struct Node *nd_Create(void *ptr, struct Node *NextNode){	struct Node *newptr;	if ((newptr = malloc(sizeof(struct Node))) == NULL)	{		perror("nd_create, malloc");		return (NULL);	}	newptr->DataPtr = ptr;	newptr->Next = NextNode;	return(newptr);}/*  ===============================================================================    Function: 	nd_Destroy    Args: 		A pointer to a node to be free()'d    Returns: 	Nothing    Purpose:	The data the node points to is not freed by the function,     			only the node itself is.  =============================================================================== */void nd_Destroy(struct Node *ptr){	free(ptr);}/*  ===============================================================================    Function: 	li_Traverse    Args: 		A pointer to the first node in the list    			A pointer to a function used to process each node.    Returns: 	Number of Nodes processed    Purpose:	Traverse the list, sending each nodes data to a function  =============================================================================== */int li_Traverse(struct Node *List, FPTR_Action fptr_Action){	struct Node *Current = List;	int Count = 0;		while (Current)	{		fptr_Action(Current->DataPtr);		Count++;		Current = Current->Next;	}	return (Count);}/*  ===============================================================================    Function: 	li_Insert    Args: 		A pointer to the first node in the list    			A pointer to the data to be referenced by the node    			A pointer to a function to be used for comparison.    Returns: 	Pointer to the first node in the list    			NULL is nd_Create fails.    Notes:		The caller should use caution to ensure the List pointer    			is not lost if this function returns NULL.    Purpose:	Inserts a new node into the list in the correct sorted order.  =============================================================================== */struct Node *li_Insert(struct Node *List, void *NewData, FPTR_Compare fptr_Compare){	struct Node *newptr;	struct Node *Current = List;	struct Node *Previous = NULL;		while (Current)	{		if (fptr_Compare(Current->DataPtr, NewData) > 0)			break; /* Found the entry point */		Previous = Current; 		Current = Current->Next;	}		if ((newptr = nd_Create(NewData, Current)) == NULL)	{	/* malloc failure in nd_Create */		return (NULL);	}		if (Previous == NULL)		List = newptr;	else		Previous->Next = newptr;		gl_HighestID++;	return (List);}/*  ===============================================================================    Function: 	li_Destroy    Args: 		A pointer to the first node in the list    Returns: 	Nothing    Purpose:	This runs through the list, destroying nodes.  It does    			not free the data that each node points to.  =============================================================================== */struct Node *li_Destroy(struct Node *List){	struct Node *Current = List;	struct Node *tmp;		while (Current)	{		tmp = Current->Next;		nd_Destroy(Current);		Current = tmp;	}	gl_HighestID = 0;		return (NULL);}/*  ===============================================================================    Function: 	li_GetDataPtrByID    Args: 		A pointer to the first node in the list    			An int for the ID field.    Returns: 	Pointer to a Record struct, allowing direct access by the caller    Purpose:	Gets the address of a Record structure, as *owned* by the list.  ===============================================================================*/struct Record *li_GetDataPtrByID(struct Node *List, int ID){	struct Node *Current = List;	struct Record *rec;		while (Current)	{		rec = Current->DataPtr;		if (rec->ID == ID)			break;		Current = Current->Next;	}	return ((Current)?Current->DataPtr:NULL);}/*  ===============================================================================    Function: 	li_DeleteNodeAndData    Args: 		A pointer to the first node in the list    			A pointer to the data to be referenced by the node    			A pointer to a function to be used for comparison.    Returns: 	Pointer to the first node in the list    			NULL is nd_Create fails.    Notes:		The caller should use caution to ensure the List pointer    			is not lost if this function returns NULL.    Purpose:	As the function name says!  =============================================================================== */struct Node *li_DeleteNodeAndData(struct Node *List, void *CompareData, FPTR_CompareDelete fptr_Compare){	struct Node *Current = List;	struct Node *Previous = NULL;	struct Node *tmp;		while (Current)	{		if (fptr_Compare(Current->DataPtr, CompareData) > 0)		{	/* Found a node to remove */			if (Current == List) List = Current->Next;			tmp = Current->Next;			if (Previous)			{				Previous->Next = tmp;			}			free (Current->DataPtr);			free (Current);			Current = tmp;		}		else		{	/* No match, move on */			Previous = Current; 			Current = Current->Next;		}	}		return (List);}/*  ===============================================================================    Function: 	li_Count    Args: 		A pointer to the first node in the list    Returns: 	Number of Nodes in list    Purpose:	Counts the nodes.  =============================================================================== */int li_Count(struct Node *List){	struct Node *Current = List;	int Count = 0;		while (Current)	{		Count++;		Current = Current->Next;	}	return (Count);}/*  ===============================================================================    Function: 	li_Sort    Args: 		A pointer to the first node in the list    			Function pointer used for comparisons    Returns: 	None    Purpose:	Sorts the nodes, using the given function.  =============================================================================== */void li_Sort(struct Node *List,  FPTR_Compare fptr_Compare){	struct Node *Current, *Next;	void *Temp;	bool_t StillDoingSwaps = TRUE;		while (StillDoingSwaps == TRUE)	{		StillDoingSwaps = FALSE;		Current = List;		while (Current)		{			if ((Next = Current->Next) != NULL)			{				if (fptr_Compare (Current->DataPtr, Next->DataPtr) > 0)				{					Temp = Current->DataPtr;					Current->DataPtr = Next->DataPtr;					Next->DataPtr = Temp;					StillDoingSwaps = TRUE;				}			}			Current = Next;		}	}}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲高清不卡在线观看| 欧美大片一区二区三区| 国产精品少妇自拍| 高清av一区二区| 国产精品网站在线观看| 9久草视频在线视频精品| 亚洲欧洲另类国产综合| 色婷婷精品大视频在线蜜桃视频| 亚洲精品写真福利| 欧美色精品在线视频| 午夜不卡在线视频| 欧美一区二区三区思思人| 免费欧美日韩国产三级电影| 亚洲精品在线免费播放| 国产乱码精品一区二区三区五月婷| 国产视频不卡一区| 成人激情视频网站| 亚洲女人****多毛耸耸8| 欧美三电影在线| 久久99精品久久久久久动态图| 26uuu国产在线精品一区二区| 国产高清不卡一区| 一区二区三区欧美久久| 欧美丰满美乳xxx高潮www| 久久国内精品视频| 中文字幕一区二区三| 欧美综合一区二区| 久久99蜜桃精品| 欧美国产丝袜视频| 欧美男男青年gay1069videost| 久久99精品久久久久| 中文字幕永久在线不卡| 91超碰这里只有精品国产| 久久99国产精品尤物| 专区另类欧美日韩| 56国语精品自产拍在线观看| 成人在线综合网站| 日韩 欧美一区二区三区| 午夜成人免费视频| 国产日韩欧美在线一区| 欧美日精品一区视频| 国产成人精品一区二| 午夜av电影一区| 中国色在线观看另类| 91麻豆精品国产91久久久资源速度 | 欧美亚洲国产一区二区三区va| 美腿丝袜一区二区三区| 亚洲欧美日韩小说| 久久久久久久网| 欧美日韩专区在线| www.综合网.com| 久久激情综合网| 午夜久久久影院| 亚洲男人的天堂网| 国产亚洲1区2区3区| 91精品国产综合久久久久久| 91女厕偷拍女厕偷拍高清| 国精产品一区一区三区mba视频| 亚洲福利电影网| 日韩一区欧美一区| 国产午夜精品在线观看| 欧美一区二区三区精品| 在线亚洲欧美专区二区| 成人精品一区二区三区中文字幕| 久草在线在线精品观看| 天堂蜜桃91精品| 亚洲在线成人精品| 一区二区三区四区精品在线视频| 欧美国产视频在线| 欧美国产一区视频在线观看| 久久女同精品一区二区| 精品少妇一区二区三区视频免付费| 欧美日韩一二三| 欧美曰成人黄网| 欧美在线观看一区二区| 色成年激情久久综合| av一区二区不卡| 不卡的电视剧免费网站有什么| 国产一区二区看久久| 国模套图日韩精品一区二区| 久久99在线观看| 韩国一区二区视频| 国产一区二区福利| 国产美女在线精品| 成人综合激情网| 成人污视频在线观看| 99久久99久久免费精品蜜臀| 91影院在线免费观看| 在线视频观看一区| 欧美日产在线观看| 欧美一级日韩不卡播放免费| 日韩欧美国产不卡| 久久久久久久综合日本| 国产精品久久久久三级| 成人免费在线视频观看| 一区二区三区欧美亚洲| 午夜亚洲福利老司机| 日韩电影在线观看网站| 精品一区二区国语对白| 国产精品资源在线| 成人h版在线观看| 欧美性猛交xxxx乱大交退制版 | 色94色欧美sute亚洲线路一久| 日本精品免费观看高清观看| 欧美亚洲动漫制服丝袜| 91精品国产色综合久久不卡电影| 欧美va亚洲va国产综合| 欧美国产日本韩| 亚洲一区在线电影| 奇米影视7777精品一区二区| 国产精品69毛片高清亚洲| 成人美女视频在线观看| 在线精品视频免费观看| 日韩一二在线观看| 中文字幕在线免费不卡| 亚洲成人tv网| 国产一区二区伦理| 欧美亚洲日本一区| 久久久美女艺术照精彩视频福利播放| 中文一区二区在线观看| 亚洲国产综合91精品麻豆| 久久电影网电视剧免费观看| 不卡的电视剧免费网站有什么| 91精品中文字幕一区二区三区| 久久这里只精品最新地址| 亚洲久本草在线中文字幕| 麻豆精品在线播放| 91小视频免费看| 欧美电视剧免费观看| 亚洲三级在线看| 精品亚洲国内自在自线福利| 色激情天天射综合网| 久久亚洲精品国产精品紫薇| 亚洲在线中文字幕| 国产成人av电影在线| 538prom精品视频线放| 亚洲图片欧美激情| 国产在线国偷精品产拍免费yy| 91福利在线观看| 国产欧美精品在线观看| 日韩不卡一二三区| 色婷婷精品大视频在线蜜桃视频| 国产日韩欧美一区二区三区乱码| 视频一区视频二区中文字幕| eeuss鲁一区二区三区| 日韩欧美在线1卡| 亚洲一区二区三区视频在线播放| 国产成人av电影在线| 精品国产乱码久久久久久浪潮| 亚洲国产综合视频在线观看| 91在线你懂得| 日本一区二区视频在线| 麻豆91精品视频| 精品视频免费看| 亚洲最新视频在线观看| 99久久免费精品| 中文无字幕一区二区三区 | 色综合久久久久综合99| 国产日韩欧美综合在线| 国产综合色在线视频区| 91精选在线观看| 午夜激情久久久| 在线观看91av| 五月婷婷另类国产| 欧美日精品一区视频| 亚洲一区二区三区美女| 色婷婷久久久综合中文字幕| 亚洲女与黑人做爰| 在线免费av一区| 夜色激情一区二区| 欧美四级电影网| 亚洲国产精品久久久久婷婷884 | 首页国产欧美久久| 欧美精品自拍偷拍动漫精品| 午夜欧美大尺度福利影院在线看| 欧美日韩一区二区三区在线看| 亚洲一区二区三区三| 欧美日韩不卡一区二区| 午夜精品久久久久久久久久久 | 亚洲国产成人va在线观看天堂| 欧美日韩专区在线| 日韩精品国产精品| 精品国产露脸精彩对白| 国模一区二区三区白浆| 欧美激情一区二区在线| 北条麻妃一区二区三区| 亚洲三级久久久| 欧美在线免费观看视频| 石原莉奈在线亚洲三区| 亚洲精品一区二区三区四区高清 | 欧美视频在线播放| 午夜精品福利一区二区蜜股av | 老司机精品视频在线| 欧美va亚洲va| 粉嫩一区二区三区在线看| 亚洲免费视频成人| 91麻豆精品国产91久久久资源速度 | av电影在线观看不卡| 亚洲一区二区精品久久av| 日韩一二三区视频|