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

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

?? avltree.c

?? http://gaul.sourceforge.net/ 這里大部分人討論的是在Matlab里實(shí)現(xiàn)GA的toolbox.以上為一個(gè)GA的C語言的軟件包.如果你想利用GA做優(yōu)化算法,非常有用.而且有
?? C
?? 第 1 頁 / 共 2 頁
字號(hào):
/**********************************************************************  avltree.c **********************************************************************  avltree - AVL tree implementation.  Copyright ?2000-2004, Stewart Adcock <stewart@linux-domain.com>  All rights reserved.  The latest version of this program should be available at:  http://gaul.sourceforge.net/  This program is free software; you can redistribute it and/or modify  it under the terms of the GNU General Public License as published by  the Free Software Foundation; either version 2 of the License, or  (at your option) any later version.  Alternatively, if your project  is incompatible with the GPL, I will probably agree to requests  for permission to use the terms of any other license.  This program is distributed in the hope that it will be useful, but  WITHOUT ANY WARRANTY WHATSOEVER.  A full copy of the GNU General Public License should be in the file  "COPYING" provided with this distribution; if not, see:  http://www.gnu.org/ **********************************************************************  Synopsis:	 AVL trees.		(Adel'son-Velskii and Landis Tree, or height-balanced		1-tree (!))  References:	Just about any datastructure text book. 		I have stubbs & webre (1985, Wadsworth Inc.) 		Much of this code comes from the GLIB gtree.c source. 		Differences to the Balanced Binary Tree code in GLIB:		  - degenerate keys are stored (I needed this - BUT NOT YET IMPLEMENTED)		  - opaque key generation (for usability)		  - primitive key comparison (for rapid comparisons)		  - traverse in order only (for small footprint)		  - no search function (a bit useless anyway)		  - additional avltree_lookup_{lowest|highest}() functions (Useful)		  - data returned after removing node (Useful - NULL means nothing removed)		  - avltree_destroy for cleaning+deleteing a tree (useful)                  - OpenMP code (shared memory parallelisation) 		By default the keys are unsigned longs, but this may		be overridden at compile time by defining the constant		AVLTREE_KEY_TYPE. 		This code should be thread safe.		For OpenMP code, USE_OPENMP must be defined and 		avltree_init_openmp() must be called prior to any other		function.		A basic test program may be compiled with something like:		gcc avltree.c -DAVLTREE_COMPILE_MAIN -g   To do:	rebuilding tree after changing key/hashing function. 		remove function return success flag. 		convert some recursive functions into iterative functions where sensible (e.g. avltree_node_count)		Use the memory_chunk allocators.  This should now be safe. **********************************************************************/#include "gaul/avltree.h"/* * Private node data structure. */typedef struct AVLNode_t  {  struct AVLNode_t *left;	/* Left subtree. */  struct AVLNode_t *right;	/* Right subtree. */  int		balance;	/* Height (left) - height (right). */  AVLKey	key;		/* The key for this node. */  vpointer	data;		/* Data stored at this node. */  } AVLNode;/* * Private function prototypes. */static AVLNode	*avltree_node_new(AVLKey key, vpointer data);static void	avltree_node_free(AVLNode *node);static void	avltree_node_delete(AVLNode *node);static AVLNode	*avltree_node_insert(AVLNode *node, AVLKey key,				     vpointer data, boolean *inserted);static AVLNode	*avltree_node_remove(AVLNode *node,                                     AVLKey key, vpointer *removed_data);static AVLNode	*avltree_node_balance(AVLNode *node);static AVLNode	*avltree_node_remove_leftmost(AVLNode *node,					     AVLNode **leftmost);static AVLNode	*avltree_node_restore_left_balance(AVLNode *node,						     int old_balance);static AVLNode	*avltree_node_restore_right_balance(AVLNode *node,						     int old_balance);static vpointer	avltree_node_lookup(AVLNode *node, AVLKey key);static int	avltree_node_count(AVLNode *node);static boolean	avltree_node_traverse(AVLNode *node,				AVLTraverseFunc traverse_func, vpointer userdata);static int	avltree_node_height(AVLNode *node);static AVLNode	*avltree_node_rotate_left(AVLNode *node);static AVLNode	*avltree_node_rotate_right(AVLNode *node);static void	avltree_node_check(AVLNode *node);/* * Compilation constants. */#define AVL_NODE_BUFFER_NUM_INCR	16#define AVL_NODE_BUFFER_SIZE		1024/* * Global variables. */static int		AVLnum_trees = 0;	/* Count number of trees in use. */static int		buffer_num = -1;static int		num_buffers = 0;static int		num_used = AVL_NODE_BUFFER_SIZE;static AVLNode		**node_buffers = NULL;static AVLNode		*node_free_list = NULL;/* * Note that a single coarse thread lock is used when a number of * less coarse locks might be better. */THREAD_LOCK_DEFINE_STATIC(avltree_node_buffer_lock);#if USE_OPENMP == 1static boolean avltree_openmp_initialised = FALSE;#endif/* * Private functions. *//* * Deallocate all memory associated with buffers.  Should * never be called outside of a "avltree_node_buffer_lock" * block. */static void _destroy_buffers(void)  {  while (buffer_num >= 0)    {    s_free(node_buffers[buffer_num]);    buffer_num--;    }  s_free(node_buffers);  node_buffers = NULL;  num_buffers = 0;  num_used = AVL_NODE_BUFFER_SIZE;  node_free_list = NULL;  return;  }static AVLNode *avltree_node_new(AVLKey key, vpointer data)  {  AVLNode *node;  THREAD_LOCK(avltree_node_buffer_lock);/* * Find an unused node.  Look for unused node in current buffer, then * in the free node list, then allocate new buffer. */  if (num_used < AVL_NODE_BUFFER_SIZE)    {    node = &(node_buffers[buffer_num][num_used]);    num_used++;    }  else    {    if (node_free_list!=NULL)      {      node = node_free_list;      node_free_list = node->right;      }    else      {      buffer_num++;      if (buffer_num == num_buffers)        {        num_buffers += AVL_NODE_BUFFER_NUM_INCR;        node_buffers = s_realloc(node_buffers, sizeof(AVLNode *)*num_buffers);        }      node_buffers[buffer_num] = s_malloc(sizeof(AVLNode)*AVL_NODE_BUFFER_SIZE);      node = node_buffers[buffer_num];      num_used = 1;      }    }  THREAD_UNLOCK(avltree_node_buffer_lock);  node->balance = 0;  node->left = NULL;  node->right = NULL;  node->key = key;  node->data = data;  return node;  }static void avltree_node_free(AVLNode *node)  {  THREAD_LOCK(avltree_node_buffer_lock);  node->right = node_free_list;  node_free_list = node;  THREAD_UNLOCK(avltree_node_buffer_lock);  return;  }static void avltree_node_delete(AVLNode *node)  {	    if (node!=NULL)    {    avltree_node_delete(node->right);    avltree_node_delete(node->left);    avltree_node_free(node);    }  return;  }/* * Actually, an iterative version would be preferable... */static void avltree_node_destroy(AVLNode *node, AVLDestructorFunc free_func)  {	    if (node!=NULL)    {    avltree_node_destroy(node->right, free_func);    avltree_node_destroy(node->left, free_func);    free_func(node->data);    avltree_node_free(node);    }  return;  }/* * Systematically search tree with a search function which has the * same ordering as the tree. * This iterative version is much faster than the equivalent recursive version. */static vpointer avltree_node_ordered_search(AVLNode *node,                     AVLSearchFunc search_func, vpointer userdata)  {  int dir;  while (node!=NULL)    {    dir = (*search_func)(node->data, userdata);    if (dir<0)      node=node->left;    else if (dir>0)      node=node->right;    else      return node->data;    }  return NULL;  }/* * Systematically search tree until AVLMatchFunc returns TRUE. * This can be fairly slow!  Don't say I didn't warn you. */static boolean avltree_node_search(AVLNode *node,                     AVLMatchFunc search_func, vpointer userdata, vpointer *node_data)  {  *node_data=node->data;  if ((*search_func)(*node_data, userdata)) return TRUE;  if (node->left!=NULL)    if (avltree_node_search(node->left, search_func, userdata, node_data))      return TRUE;  if (node->right!=NULL)    if (avltree_node_search(node->right, search_func, userdata, node_data))      return TRUE;  return FALSE;  }static AVLNode *avltree_node_insert(AVLNode *node,		    AVLKey key, vpointer data, boolean *inserted)  {  int old_balance;  if (!node)    {    *inserted = TRUE;    return avltree_node_new(key, data);    }  if (key < node->key)    {    if (node->left!=NULL)      {      old_balance = node->left->balance;      node->left = avltree_node_insert(node->left, key, data, inserted);      if ((old_balance != node->left->balance) && node->left->balance)        node->balance--;      }    else      {      *inserted = TRUE;      node->left = avltree_node_new(key, data);      node->balance--;      }    }  else if (key > node->key)    {    if (node->right!=NULL)      {      old_balance = node->right->balance;      node->right = avltree_node_insert(node->right, key, data, inserted);      if ((old_balance != node->right->balance) && node->right->balance)        node->balance++;      }    else      {      *inserted = TRUE;      node->right = avltree_node_new(key, data);      node->balance++;      }    }  else    {	/* key == node->key *//*    *inserted = FALSE; */    printf("WARNING: -- Replaced node -- (Key clash?)\n");    node->data = data;    return node;    }  if (*inserted!=FALSE && (node->balance < -1 || node->balance > 1))    node = avltree_node_balance(node);  return node;  }static AVLNode *avltree_node_remove(AVLNode *node,                            AVLKey key, vpointer *removed_data)  {  AVLNode	*new_root=NULL;  int		old_balance;  if (!node) return NULL;  if (key < node->key)    {    if (node->left!=NULL)      {      old_balance = node->left->balance;      node->left = avltree_node_remove(node->left, key, removed_data);      node = avltree_node_restore_left_balance(node, old_balance);      }    }  else if (key > node->key)    {    if (node->right!=NULL)      {      old_balance = node->right->balance;      node->right = avltree_node_remove(node->right, key, removed_data);      node = avltree_node_restore_right_balance(node, old_balance);      }    }  else if (key == node->key)    {    AVLNode *removed_node;    removed_node = node;    if (!node->right)      {      node = node->left;      }    else      {      old_balance = node->right->balance;      node->right = avltree_node_remove_leftmost(node->right, &new_root);      if (new_root==NULL) die("Internal error.  New root node is NULL.");      new_root->left = node->left;      new_root->right = node->right;      new_root->balance = node->balance;      node = avltree_node_restore_right_balance(new_root, old_balance);      }    *removed_data = removed_node->data;    avltree_node_free(removed_node);    }  return node;  }static AVLNode *avltree_node_balance(AVLNode *node)  {  if (node->balance < -1)    {    if (node->left->balance > 0)      node->left = avltree_node_rotate_left(node->left);    node = avltree_node_rotate_right(node);    }  else if (node->balance > 1)    {    if (node->right->balance < 0)      node->right = avltree_node_rotate_right(node->right);    node = avltree_node_rotate_left(node);    }  return node;  }static AVLNode *avltree_node_remove_leftmost(AVLNode  *node,			     AVLNode **leftmost)  {  int old_balance;  if (!node->left)    {    *leftmost = node;    return node->right;    }  old_balance = node->left->balance;  node->left = avltree_node_remove_leftmost(node->left, leftmost);  return avltree_node_restore_left_balance(node, old_balance);  }static AVLNode *avltree_node_lookup_leftmost(AVLNode *node)  {/* Recursive version:  if (!node->left) return node;  return avltree_node_lookup_leftmost(node->left); */  while (node->left!=NULL) node = node->left;  return node;  }static AVLNode *avltree_node_lookup_rightmost(AVLNode *node)  {/* Recursive version:  if (!node->right) return node;  return avltree_node_lookup_rightmost(node->right); */  while (node->right!=NULL) node = node->right;  return node;  }static AVLNode *avltree_node_restore_left_balance(AVLNode	*node,				  int		old_balance)  {  if ( (!node->left) || ((node->left->balance != old_balance) &&           (node->left->balance == 0)) )    {    node->balance++;    }  if (node->balance > 1) return avltree_node_balance(node);  return node;  }static AVLNode *avltree_node_restore_right_balance(AVLNode	*node,				   int		old_balance)  {  if ( (!node->right) || ((node->right->balance != old_balance) &&	   (node->right->balance == 0)) )    {    node->balance--;    }  if (node->balance < -1) return avltree_node_balance(node);  return node;  }#if 0/* Recursive version */static vpointer avltree_node_lookup(AVLNode *node, AVLKey key)  {  if (!node) return NULL;  if (key < node->key)    {    if (node->left) return avltree_node_lookup(node->left, key);    }  else if (key > node->key)    {

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩一区在线播放| 91九色02白丝porn| 亚洲日本在线看| 欧美一级一级性生活免费录像| 国产精品1区2区3区| 亚洲国产精品久久久久秋霞影院| 欧美激情综合网| 精品久久久久香蕉网| 欧美日韩一本到| 一本色道久久综合亚洲aⅴ蜜桃| 久久精品国产99| 亚洲成人一区二区| 亚洲欧美视频在线观看视频| 国产人成亚洲第一网站在线播放| 91精品国产综合久久久久久久久久| caoporm超碰国产精品| 国产在线精品一区二区三区不卡 | 久久久久国产精品麻豆| 在线观看91精品国产麻豆| 91无套直看片红桃| 成人午夜精品在线| 亚洲精品久久嫩草网站秘色| 亚洲综合清纯丝袜自拍| 国产欧美一区二区在线| 日韩欧美国产综合| 欧美乱熟臀69xxxxxx| 欧美日韩免费不卡视频一区二区三区 | 日韩一区二区高清| 欧美日韩在线不卡| 欧美日韩在线免费视频| 欧美综合色免费| 欧美亚州韩日在线看免费版国语版| 成人av免费观看| 不卡一区中文字幕| av中文字幕不卡| 成人一级黄色片| 成人av网站免费观看| 成人av综合一区| 97久久久精品综合88久久| av毛片久久久久**hd| 不卡的av网站| 色婷婷狠狠综合| 欧美亚洲综合网| 欧美日韩精品一区视频| 亚洲精品国产a| 欧美日韩精品欧美日韩精品| 欧美无人高清视频在线观看| 欧美群妇大交群的观看方式| 欧美精品三级日韩久久| 欧美一区二区三区白人| 精品奇米国产一区二区三区| 久久亚洲捆绑美女| 中文字幕av一区二区三区| 国产精品久久久久久久浪潮网站 | 久久超碰97人人做人人爱| 久久99国产精品久久99果冻传媒| 久久爱www久久做| 国产成人精品亚洲777人妖| 成人黄色网址在线观看| 色丁香久综合在线久综合在线观看| 在线看一区二区| 91精品国产乱码| 久久综合色婷婷| 国产精品理论在线观看| 亚洲gay无套男同| 久久se精品一区精品二区| 91精品欧美福利在线观看| 国产精品久久午夜夜伦鲁鲁| 中文字幕中文字幕中文字幕亚洲无线 | 精品在线播放午夜| 高清在线不卡av| 在线免费观看成人短视频| 日韩欧美中文一区二区| 中文字幕va一区二区三区| 亚洲一二三四久久| 国产在线国偷精品产拍免费yy| zzijzzij亚洲日本少妇熟睡| 欧美日韩国产天堂| 国产欧美视频一区二区三区| 亚洲精品v日韩精品| 久久精品国产久精国产爱| 成人高清免费观看| 欧美一级艳片视频免费观看| 亚洲欧洲av在线| 蜜桃久久久久久| 91黄视频在线| 久久精品一区八戒影视| 亚洲国产一区二区在线播放| 国产乱子伦一区二区三区国色天香| 色94色欧美sute亚洲13| 亚洲国产成人在线| 亚洲综合激情网| 青青草一区二区三区| 波多野洁衣一区| 日韩午夜电影av| 一区二区高清在线| 国产黑丝在线一区二区三区| 91麻豆精品国产91久久久久| 国产精品电影一区二区三区| 激情综合一区二区三区| 欧美性大战久久久久久久蜜臀| 久久久精品欧美丰满| 天天色 色综合| 日本韩国欧美在线| 国产欧美一区二区三区网站| 麻豆视频观看网址久久| 欧美日韩国产天堂| 亚洲精品乱码久久久久久久久 | 蜜臀久久久99精品久久久久久| 99这里只有精品| 久久综合色8888| 免费在线观看视频一区| 麻豆精品在线观看| jlzzjlzz国产精品久久| 久久亚洲综合av| 免费精品视频在线| 69堂国产成人免费视频| 尤物av一区二区| 99精品视频在线免费观看| 久久久久久97三级| 捆绑调教一区二区三区| 91精品国模一区二区三区| 亚洲第一精品在线| 欧美日韩一级黄| 亚洲图片欧美综合| 欧美综合天天夜夜久久| 一区二区三区在线视频播放| 99re8在线精品视频免费播放| 国产女人18毛片水真多成人如厕| 国产麻豆午夜三级精品| 精品va天堂亚洲国产| 精品一区二区综合| 色婷婷国产精品综合在线观看| 精品欧美一区二区在线观看| 青青青伊人色综合久久| 欧美一级夜夜爽| 久久99精品久久久久| 2020国产精品自拍| 久久伊99综合婷婷久久伊| 久热成人在线视频| 国产精品萝li| 免费av成人在线| 国产精品毛片大码女人| 色狠狠色噜噜噜综合网| 蜜桃av噜噜一区| 中文字幕一区二区三区在线不卡| 欧美人xxxx| 成人免费视频视频在线观看免费| 亚洲午夜一区二区三区| 久久网站最新地址| 在线视频国产一区| 国内精品国产三级国产a久久| 一区二区在线观看免费| 精品国产一区二区在线观看| 在线欧美日韩国产| 国产一区二区影院| 亚洲国产cao| 国产精品理论在线观看| 欧美一区二区三区在线电影 | 精品久久人人做人人爱| 色94色欧美sute亚洲线路二| 国产高清不卡一区| 首页国产欧美久久| 亚洲乱码中文字幕| 久久久亚洲精品石原莉奈 | 亚洲午夜激情网页| 国产日韩成人精品| 日韩欧美色综合网站| 欧美色图一区二区三区| 大陆成人av片| 久久精品国产澳门| 亚洲 欧美综合在线网络| 国产一区二区三区四| 欧美亚洲综合网| 国产成人av一区二区三区在线观看| 亚洲最大成人网4388xx| 亚洲国产精品传媒在线观看| 欧美成人r级一区二区三区| 欧美性高清videossexo| 不卡大黄网站免费看| 国产高清不卡二三区| 久久er99热精品一区二区| 五月婷婷激情综合网| 伊人开心综合网| 一区二区中文视频| 欧美国产综合色视频| 久久久精品一品道一区| 精品99一区二区| 日韩视频一区二区在线观看| 91麻豆精品国产无毒不卡在线观看 | 成人av在线一区二区| 激情小说亚洲一区| 久久精品国产免费看久久精品| 日韩在线一区二区| 五月综合激情婷婷六月色窝| 亚洲国产综合视频在线观看| 一区二区三区欧美久久| 亚洲精品ww久久久久久p站| 亚洲卡通动漫在线| 亚洲欧美在线aaa|