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

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

?? minpq.c

?? Rob Hess Linux下的SIFT提取源碼
?? C
字號:
/*  Functions and structures for implementing a minimizing priority queue.    Copyright (C) 2006-2007  Rob Hess <hess@eecs.oregonstate.edu>  @version 1.1.1-20070913*/#include "minpq.h"#include "utils.h"#include <limits.h>/************************* Local Function Prototypes *************************/void restore_minpq_order( struct pq_node*, int, int );void decrease_pq_node_key( struct pq_node*, int, int );/************************** Local Inline Functions ***************************//* returns the array index of element i's parent */static inline int parent( int i ){  return ( i - 1 ) / 2;}/* returns the array index of element i's right child */static inline int right( int i ){  return 2 * i + 2;}/* returns the array index of element i's left child */static inline int left( int i ){  return 2 * i + 1;}/********************** Functions prototyped in minpq.h **********************//*  Creates a new minimizing priority queue.*/struct min_pq* minpq_init(){  struct min_pq* min_pq;  min_pq = malloc( sizeof( struct min_pq ) );  min_pq->pq_array = calloc( MINPQ_INIT_NALLOCD, sizeof( struct pq_node ) );  min_pq->nallocd = MINPQ_INIT_NALLOCD;  min_pq->n = 0;  return min_pq;}/**  Inserts an element into a minimizing priority queue.  @param min_pq a minimizing priority queue  @param data the data to be inserted  @param key the key to be associated with \a data  @return Returns 0 on success or 1 on failure.*/int minpq_insert( struct min_pq* min_pq, void* data, int key ){  int n = min_pq->n;  /* double array allocation if necessary */  if( min_pq->nallocd == n )    {      min_pq->nallocd = array_double( &min_pq->pq_array, min_pq->nallocd,				      sizeof( struct pq_node ) );      if( ! min_pq->nallocd )	{	  fprintf( stderr, "Warning: unable to allocate memory, %s, line %d\n",		   __FILE__, __LINE__ );	  return 1;	}    }  min_pq->pq_array[n].data = data;  min_pq->pq_array[n].key = INT_MAX;  decrease_pq_node_key( min_pq->pq_array, min_pq->n, key );  min_pq->n++;  return 0;}/*  Returns the element of a minimizing priority queue with the smallest key  without removing it from the queue.    @param min_pq a minimizing priority queue    @return Returns the element of \a min_pq with the smallest key or NULL    if \a min_pq is empty*/void* minpq_get_min( struct min_pq* min_pq ){  if( min_pq->n < 1 )    {      fprintf( stderr, "Warning: PQ empty, %s line %d\n", __FILE__, __LINE__ );      return NULL;    }  return min_pq->pq_array[0].data;}/*  Removes and returns the element of a minimizing priority queue with the  smallest key.    @param min_pq a minimizing priority queue    @return Returns the element of \a min_pq with the smallest key of NULL    if \a min_pq is empty*/void* minpq_extract_min( struct min_pq* min_pq ){  void* data;  if( min_pq->n < 1 )    {      fprintf( stderr, "Warning: PQ empty, %s line %d\n", __FILE__, __LINE__ );      return NULL;    }  data = min_pq->pq_array[0].data;  min_pq->n--;  min_pq->pq_array[0] = min_pq->pq_array[min_pq->n];  restore_minpq_order( min_pq->pq_array, 0, min_pq->n );  return data;}/*  De-allocates the memory held by a minimizing priorioty queue    @param min_pq pointer to a minimizing priority queue*/void minpq_release( struct min_pq** min_pq ){  if( ! min_pq )    {      fprintf( stderr, "Warning: NULL pointer error, %s line %d\n", __FILE__,	       __LINE__ );      return;    }  if( *min_pq  &&  (*min_pq)->pq_array )    {      free( (*min_pq)->pq_array );      free( *min_pq );      *min_pq = NULL;    }}/************************ Functions prototyped here **************************//*  Decrease a minimizing pq element's key, rearranging the pq if necessary  @param pq_array minimizing priority queue array  @param i index of the element whose key is to be decreased  @param key new value of element <EM>i</EM>'s key; if greater than current    key, no action is taken*/void decrease_pq_node_key( struct pq_node* pq_array, int i, int key ){  struct pq_node tmp;  if( key > pq_array[i].key )    return;  pq_array[i].key = key;  while( i > 0  &&  pq_array[i].key < pq_array[parent(i)].key )    {      tmp = pq_array[parent(i)];      pq_array[parent(i)] = pq_array[i];      pq_array[i] = tmp;      i = parent(i);    }}/*  Recursively restores correct priority queue order to a minimizing pq array  @param pq_array a minimizing priority queue array  @param i index at which to start reordering  @param n number of elements in \a pq_array*/void restore_minpq_order( struct pq_node* pq_array, int i, int n ){  struct pq_node tmp;  int l, r, min = i;  l = left( i );  r = right( i );  if( l < n )    if( pq_array[l].key < pq_array[i].key )      min = l;  if( r < n )    if( pq_array[r].key < pq_array[min].key )      min = r;  if( min != i )    {      tmp = pq_array[min];      pq_array[min] = pq_array[i];      pq_array[i] = tmp;      restore_minpq_order( pq_array, min, n );    }}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日本中文字幕一区二区视频| 欧美日韩在线一区二区| 91看片淫黄大片一级在线观看| 精品视频免费在线| 国产精品久久久久9999吃药| 美女一区二区三区| 色婷婷精品久久二区二区蜜臀av| 日韩一区二区视频在线观看| 亚洲六月丁香色婷婷综合久久| 国产精品一区二区三区乱码| 欧美精品高清视频| 亚洲一级片在线观看| av成人老司机| 久久精品欧美日韩| 精品在线一区二区三区| 欧美日韩精品欧美日韩精品一| 亚洲视频免费在线| www.一区二区| 国产精品剧情在线亚洲| 国产成人亚洲精品青草天美| 精品噜噜噜噜久久久久久久久试看| 亚洲成人激情av| 91成人看片片| 一区二区三区视频在线观看| 激情综合五月婷婷| 欧美日韩免费视频| 亚洲不卡在线观看| 欧美日韩久久一区| 无码av免费一区二区三区试看| 色哟哟在线观看一区二区三区| 欧美国产乱子伦| 国产xxx精品视频大全| 精品精品国产高清一毛片一天堂| 日韩成人精品视频| 日韩三级视频在线看| 日韩av电影天堂| 日韩一级免费观看| 国产又黄又大久久| 国产精品久久久一本精品| 国产成人免费在线视频| 国产日本欧洲亚洲| 99精品视频在线观看| 亚洲欧洲韩国日本视频| 日本大香伊一区二区三区| 亚洲男同1069视频| 欧美日韩免费在线视频| 久色婷婷小香蕉久久| 亚洲精品在线免费播放| 国产毛片一区二区| 综合精品久久久| 欧美日韩免费观看一区二区三区 | 国产婷婷色一区二区三区在线| 国产在线精品一区二区夜色| 国产人成亚洲第一网站在线播放| 成人综合婷婷国产精品久久免费| 亚洲欧美偷拍另类a∨色屁股| 欧美日韩精品综合在线| 黄网站免费久久| 国产精品久久久久一区| 精品视频全国免费看| 黄一区二区三区| 亚洲免费资源在线播放| 欧美一a一片一级一片| 久久国产尿小便嘘嘘| 国产精品欧美极品| 这里是久久伊人| 成人黄色软件下载| 午夜视频在线观看一区二区 | 精品在线亚洲视频| 亚洲精品菠萝久久久久久久| 在线电影院国产精品| 高清不卡在线观看| 三级成人在线视频| 亚洲特级片在线| 日韩欧美一区二区免费| 91在线免费视频观看| 激情综合五月天| 午夜精品福利一区二区蜜股av| 久久精品在这里| 91精品国产福利| 色香蕉久久蜜桃| 成人精品高清在线| 美女网站视频久久| 一区二区三区四区亚洲| 国产欧美精品一区| 日韩精品自拍偷拍| 欧美三区在线观看| aa级大片欧美| 粉嫩aⅴ一区二区三区四区五区| 一区二区高清免费观看影视大全| 国产日韩欧美一区二区三区乱码| 欧美精品在线一区二区| 色女孩综合影院| 99久久精品一区二区| 国产在线精品国自产拍免费| 日韩福利电影在线观看| 亚洲小说欧美激情另类| 亚洲日本va午夜在线影院| 国产欧美日韩久久| 国产欧美一区二区精品婷婷| 欧美肥大bbwbbw高潮| 欧美视频一区二区三区四区| 91在线观看一区二区| 国产99精品在线观看| 国产在线精品一区二区不卡了 | 国产成人av影院| 精品在线亚洲视频| 久久99精品网久久| 精品一区二区三区的国产在线播放| 亚洲国产精品视频| 亚洲精品成人在线| 亚洲一区二区欧美日韩| 亚洲精品自拍动漫在线| 日韩美女视频一区二区 | 色综合久久综合中文综合网| 成人精品视频一区二区三区 | 欧美日韩精品欧美日韩精品一 | 国产99久久久精品| 波多野洁衣一区| 91丝袜美女网| 欧美系列亚洲系列| 3d动漫精品啪啪一区二区竹菊| 欧美日高清视频| 日韩女优视频免费观看| 精品国产123| 国产欧美一区视频| 亚洲另类在线一区| 午夜精品福利一区二区三区蜜桃| 日本va欧美va精品| 黄色精品一二区| 春色校园综合激情亚洲| 一本一道综合狠狠老| 欧美优质美女网站| 日韩一区二区免费高清| 久久久噜噜噜久噜久久综合| 国产日韩成人精品| 一个色妞综合视频在线观看| 日韩成人伦理电影在线观看| 国产精品888| 91丨porny丨国产| 欧美妇女性影城| 中文成人综合网| 婷婷中文字幕一区三区| 国产乱理伦片在线观看夜一区 | 亚洲人成精品久久久久久| 同产精品九九九| 国产在线视频一区二区| 99re这里都是精品| 欧美一区二区精品久久911| 国产亚洲欧美一区在线观看| 亚洲精品一二三| 久久国产麻豆精品| 91丨九色丨黑人外教| 精品久久人人做人人爰| 亚洲欧洲精品一区二区三区不卡| 亚洲aⅴ怡春院| 岛国精品在线播放| 欧美三区在线视频| 中文字幕欧美国产| 蜜桃久久久久久久| 色女孩综合影院| 久久女同性恋中文字幕| 亚洲与欧洲av电影| 成人综合在线视频| 精品美女在线观看| 首页国产丝袜综合| 99re成人在线| 久久久精品人体av艺术| 视频一区在线播放| 日本道精品一区二区三区| 中文av字幕一区| 国产一区二区精品久久91| 欧美美女网站色| 亚洲激情中文1区| 成人国产精品免费观看视频| 91精品中文字幕一区二区三区| 成人欧美一区二区三区白人| 狠狠色狠狠色综合| 91精品国产欧美一区二区18| 国产精品国产三级国产普通话三级 | 国产精品日日摸夜夜摸av| 久久成人免费电影| 欧美一二三区精品| 视频一区二区三区入口| 在线影院国内精品| 亚洲色图在线播放| 福利视频网站一区二区三区| 欧美xxxxxxxx| 九九久久精品视频| 日韩欧美一卡二卡| 麻豆精品在线视频| 欧美第一区第二区| 精品一区二区在线播放| 欧美成人女星排名| 麻豆一区二区三区| 精品欧美一区二区在线观看| 美女任你摸久久| 日韩精品在线网站| 国产一区二区三区黄视频 | 欧美美女bb生活片|