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

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

?? heap.c

?? package of develop dns
?? C
字號:
/* * Copyright (c) 2004 by Internet Systems Consortium, Inc. ("ISC") * Copyright (c) 1997,1999 by Internet Software Consortium. * * Permission to use, copy, modify, and distribute this software for any * purpose with or without fee is hereby granted, provided that the above * copyright notice and this permission notice appear in all copies. * * THE SOFTWARE IS PROVIDED "AS IS" AND ISC DISCLAIMS ALL WARRANTIES * WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF * MERCHANTABILITY AND FITNESS.  IN NO EVENT SHALL ISC BE LIABLE FOR * ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES * WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN * ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT * OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE. *//* * Heap implementation of priority queues adapted from the following: * *	_Introduction to Algorithms_, Cormen, Leiserson, and Rivest, *	MIT Press / McGraw Hill, 1990, ISBN 0-262-03141-8, chapter 7. * *	_Algorithms_, Second Edition, Sedgewick, Addison-Wesley, 1988, *	ISBN 0-201-06673-4, chapter 11. */#if !defined(LINT) && !defined(CODECENTER)static const char rcsid[] = "$Id: heap.c,v 1.1.206.1 2004/03/09 08:33:43 marka Exp $";#endif /* not lint */#include "port_before.h"#include <stddef.h>#include <stdlib.h>#include <errno.h>#include "port_after.h"#include <isc/heap.h>/* * Note: to make heap_parent and heap_left easy to compute, the first * element of the heap array is not used; i.e. heap subscripts are 1-based, * not 0-based. */#define heap_parent(i) ((i) >> 1)#define heap_left(i) ((i) << 1)#define ARRAY_SIZE_INCREMENT 512heap_contextheap_new(heap_higher_priority_func higher_priority, heap_index_func index,	 int array_size_increment) {	heap_context ctx;	ctx = (heap_context)malloc(sizeof (struct heap_context));	if (ctx == NULL || higher_priority == NULL)		return (NULL);	ctx->array_size = 0;	if (array_size_increment == 0)		ctx->array_size_increment = ARRAY_SIZE_INCREMENT;	else		ctx->array_size_increment = array_size_increment;	ctx->heap_size = 0;	ctx->heap = NULL;	ctx->higher_priority = higher_priority;	ctx->index = index;	return (ctx);}intheap_free(heap_context ctx) {	if (ctx == NULL) {		errno = EINVAL;		return (-1);	}	if (ctx->heap != NULL)		free(ctx->heap);	free(ctx);	return (0);}static intheap_resize(heap_context ctx) {	void **new_heap;	ctx->array_size += ctx->array_size_increment;	new_heap = (void **)realloc(ctx->heap,				    (ctx->array_size) * (sizeof (void *)));	if (new_heap == NULL) {		errno = ENOMEM;		return (-1);	}	ctx->heap = new_heap;	return (0);}static voidfloat_up(heap_context ctx, int i, void *elt) {	int p;	for ( p = heap_parent(i); 	      i > 1 && ctx->higher_priority(elt, ctx->heap[p]);	      i = p, p = heap_parent(i) ) {		ctx->heap[i] = ctx->heap[p];		if (ctx->index != NULL)			(ctx->index)(ctx->heap[i], i);	}	ctx->heap[i] = elt;	if (ctx->index != NULL)		(ctx->index)(ctx->heap[i], i);}static voidsink_down(heap_context ctx, int i, void *elt) {	int j, size, half_size;	size = ctx->heap_size;	half_size = size / 2;	while (i <= half_size) {		/* find smallest of the (at most) two children */		j = heap_left(i);		if (j < size && ctx->higher_priority(ctx->heap[j+1],						     ctx->heap[j]))			j++;		if (ctx->higher_priority(elt, ctx->heap[j]))			break;		ctx->heap[i] = ctx->heap[j];		if (ctx->index != NULL)			(ctx->index)(ctx->heap[i], i);		i = j;	}	ctx->heap[i] = elt;	if (ctx->index != NULL)		(ctx->index)(ctx->heap[i], i);}intheap_insert(heap_context ctx, void *elt) {	int i;	if (ctx == NULL || elt == NULL) {		errno = EINVAL;		return (-1);	}	i = ++ctx->heap_size;	if (ctx->heap_size >= ctx->array_size && heap_resize(ctx) < 0)		return (-1);		float_up(ctx, i, elt);	return (0);}intheap_delete(heap_context ctx, int i) {	void *elt;	int less;	if (ctx == NULL || i < 1 || i > ctx->heap_size) {		errno = EINVAL;		return (-1);	}	if (i == ctx->heap_size) {		ctx->heap_size--;	} else {		elt = ctx->heap[ctx->heap_size--];		less = ctx->higher_priority(elt, ctx->heap[i]);		ctx->heap[i] = elt;		if (less)			float_up(ctx, i, ctx->heap[i]);		else			sink_down(ctx, i, ctx->heap[i]);	}	return (0);}intheap_increased(heap_context ctx, int i) {     	if (ctx == NULL || i < 1 || i > ctx->heap_size) {		errno = EINVAL;		return (-1);	}		float_up(ctx, i, ctx->heap[i]);	return (0);}intheap_decreased(heap_context ctx, int i) {     	if (ctx == NULL || i < 1 || i > ctx->heap_size) {		errno = EINVAL;		return (-1);	}		sink_down(ctx, i, ctx->heap[i]);	return (0);}void *heap_element(heap_context ctx, int i) {	if (ctx == NULL || i < 1 || i > ctx->heap_size) {		errno = EINVAL;		return (NULL);	}	return (ctx->heap[i]);}intheap_for_each(heap_context ctx, heap_for_each_func action, void *uap) {	int i;	if (ctx == NULL || action == NULL) {		errno = EINVAL;		return (-1);	}	for (i = 1; i <= ctx->heap_size; i++)		(action)(ctx->heap[i], uap);	return (0);}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区三区欧美亚洲| 国产精品无码永久免费888| 色婷婷亚洲精品| 色综合天天狠狠| 91麻豆精品在线观看| 成人动漫精品一区二区| 91香蕉视频在线| 在线观看亚洲精品视频| 欧美日韩一区二区欧美激情| 欧美色图免费看| 91精品国产综合久久精品图片| 欧美美女一区二区在线观看| 这里是久久伊人| 久久色.com| 午夜久久久久久久久久一区二区| 亚洲精品中文在线影院| 亚洲成av人综合在线观看| 午夜精品久久一牛影视| 久久aⅴ国产欧美74aaa| 国产乱子伦视频一区二区三区 | 蜜臂av日日欢夜夜爽一区| 免费成人在线视频观看| 粉嫩一区二区三区性色av| 91免费看视频| 日韩丝袜情趣美女图片| 国产精品美女一区二区三区| 亚洲国产aⅴ天堂久久| 国产一区二区三区免费播放 | 欧美一级黄色大片| 7777精品伊人久久久大香线蕉| 日韩一区二区视频| 成人欧美一区二区三区黑人麻豆| 亚洲综合小说图片| 国产黄色成人av| 欧美精品在线一区二区| 国产欧美日韩不卡| 视频在线观看一区二区三区| 粉嫩aⅴ一区二区三区四区| 欧美肥妇bbw| 亚洲欧美在线视频观看| 极品少妇xxxx精品少妇偷拍| 欧美羞羞免费网站| 国产午夜亚洲精品羞羞网站| 丝袜国产日韩另类美女| 91麻豆文化传媒在线观看| 欧美成人一区二区三区在线观看| 日韩美女视频19| 国产成人自拍网| 欧美一区二区三区在线| 亚洲综合区在线| 不卡的av电影在线观看| 久久综合狠狠综合久久综合88| 亚洲线精品一区二区三区| 丁香六月综合激情| 日韩欧美一区二区不卡| 午夜电影一区二区三区| 在线观看免费一区| 国产精品乱码人人做人人爱| 黄页视频在线91| 欧美一区二区在线不卡| 亚洲成人中文在线| 日本道在线观看一区二区| 中文字幕av一区 二区| 国产高清视频一区| 26uuu亚洲| 国产福利一区在线| 久久久国产综合精品女国产盗摄| 久草精品在线观看| 精品国产乱码久久久久久1区2区| 热久久久久久久| 日韩一级成人av| 久久99精品国产.久久久久久| 欧美一区二区在线免费观看| 视频一区中文字幕国产| 欧美高清hd18日本| 免费在线观看精品| 精品电影一区二区| 国产一区二区影院| 国产精品久久久久久福利一牛影视| 懂色av一区二区夜夜嗨| 亚洲欧洲色图综合| 色94色欧美sute亚洲线路二| 亚洲一本大道在线| 69av一区二区三区| 国产一区二区三区综合| 国产精品情趣视频| 欧洲色大大久久| 蜜臀精品久久久久久蜜臀 | 成人性色生活片免费看爆迷你毛片| 久久久国产精华| 99精品国产91久久久久久| 一区二区在线观看免费| 91精品国产欧美一区二区| 九九精品视频在线看| 欧美极品另类videosde| 91搞黄在线观看| 国内精品视频666| 综合av第一页| 欧美一区二区私人影院日本| 国产精品一区2区| 亚洲综合色婷婷| 久久久久久**毛片大全| 欧美综合一区二区| 久久电影网站中文字幕| 亚洲靠逼com| 精品久久久久久综合日本欧美 | 欧美精选午夜久久久乱码6080| 麻豆精品国产91久久久久久| 国产精品毛片a∨一区二区三区| 欧美无人高清视频在线观看| 国产一区二区伦理片| 一区二区国产盗摄色噜噜| 精品国产乱码久久久久久牛牛 | 中文字幕一区二区三区乱码在线 | 亚洲视频免费在线| 日韩免费视频一区二区| 色乱码一区二区三区88 | 国产精品短视频| 91精品国产综合久久婷婷香蕉| 成人av综合在线| 国产一二精品视频| 亚洲激情图片一区| 国产精品夜夜爽| 一区二区三区视频在线看| 日韩午夜av一区| 欧美性色黄大片手机版| 中文字幕在线不卡国产视频| 欧美一区2区视频在线观看| 欧美日韩国产不卡| 日韩精品在线看片z| 国产日韩欧美激情| 亚洲精品一二三区| 一区二区激情视频| 免费观看一级欧美片| 国产成人精品亚洲777人妖| 成人听书哪个软件好| 色一区在线观看| 91麻豆精品国产91| 久久久久久久av麻豆果冻| ㊣最新国产の精品bt伙计久久| 一区二区三区视频在线看| 免费一级欧美片在线观看| 丰满白嫩尤物一区二区| 欧美四级电影在线观看| 日韩免费福利电影在线观看| 国产精品久久久久久久岛一牛影视| 亚洲动漫第一页| 国产成人综合在线播放| 在线观看欧美黄色| 久久亚洲影视婷婷| 一区二区三区小说| 精品一区二区影视| 欧美三级日本三级少妇99| 久久精品亚洲国产奇米99| 亚洲图片一区二区| jlzzjlzz欧美大全| 日韩女同互慰一区二区| 国产精品久久久久影视| 看片的网站亚洲| 一本一道久久a久久精品 | 麻豆国产欧美日韩综合精品二区| 国产成人小视频| 欧美一区二区精品在线| 亚洲日本在线视频观看| 国产精品综合av一区二区国产馆| 在线看日本不卡| 国产精品天天看| 久久成人免费网站| 555www色欧美视频| 亚洲精品老司机| 99精品国产视频| 欧美激情中文字幕| 国产在线精品一区在线观看麻豆| 欧美日韩精品电影| 亚洲人成网站色在线观看| 国产精品主播直播| 日韩欧美国产一区二区在线播放| 亚洲午夜精品17c| 色噜噜狠狠色综合欧洲selulu| 国产天堂亚洲国产碰碰| 黑人精品欧美一区二区蜜桃| 欧美人狂配大交3d怪物一区| 一区二区三区免费| 91麻豆免费看| 亚洲视频在线一区| 色综合久久中文综合久久97 | 视频在线观看一区| 欧美一a一片一级一片| 一区二区三区高清不卡| 日本精品一区二区三区高清| 成人欧美一区二区三区在线播放| 不卡电影免费在线播放一区| 亚洲国产精品高清| 丁香六月综合激情| 国产精品成人一区二区三区夜夜夜| 丁香五精品蜜臀久久久久99网站 | 久久精品视频一区二区三区| 精品一区二区三区免费观看| 久久伊人蜜桃av一区二区| 久久 天天综合|