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

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

?? sorttable.c

?? 《多任務(wù)下的數(shù)據(jù)結(jié)構(gòu)》隨書的源代碼。探討多任務(wù)下的常用數(shù)據(jù)結(jié)構(gòu)的實(shí)現(xiàn)
?? C
字號:
/*
 * Copyright (c) 2000-2008
 * Author: Weiming Zhou
 *
 * Permission to use, copy, modify, distribute and sell this software
 * and its documentation for any purpose is hereby granted without fee,
 * provided that the above copyright notice appear in all copies and
 * that both that copyright notice and this permission notice appear
 * in supporting documentation.  
 */

#include <stdlib.h>
#include "CapiGlobal.h"
#include "SortTable.h"
#include "Stack.h"

void SortTable_QuickSort2(SORTTABLE *pTable, UINT uStart, UINT uEnd, 
                        COMPAREFUNC CompareFunc);

void SortTable_QuickSort(SORTTABLE *pTable, UINT uStart, UINT uEnd, 
                        COMPAREFUNC CompareFunc);

void SortTable_QuickSort3(SORTTABLE *pTable, UINT uStart, UINT uEnd, 
                        COMPAREFUNC CompareFunc);

/**	排序表的創(chuàng)建函數(shù)

	@param	UINT uMaxCount - 排序表的最大尺寸	
	@return	SORTTABLE * - 成功返回排序表指針,失敗返回NULL	
*/
SORTTABLE *	SortTable_Create(UINT uMaxCount)
{
    SORTTABLE *pTable;

    if ( uMaxCount == 0 )
    {
        return NULL;
    }

    pTable = (SORTTABLE *)malloc(sizeof(struct SORTTABLE_st));
    if ( pTable != NULL )
    {
        pTable->ppData = (void **)malloc(uMaxCount * sizeof(void *));
        if ( pTable->ppData != NULL )
        {
            pTable->ppData[0] = NULL;
            pTable->uMaxCount = uMaxCount;
            pTable->uCursorCount = 0;
        }
        else
        {
            free( pTable );
            pTable = NULL;
        }
    }
    return pTable;
}

/**	排序表的釋放函數(shù)

	@param	SORTTABLE *pTable - 排序表指針	
	@param	DESTROYFUNC DestroyFunc - 數(shù)據(jù)釋放函數(shù)	
	@return	void - 無	
*/
void SortTable_Destroy( SORTTABLE *pTable, DESTROYFUNC DestroyFunc )
{
    if ( pTable != NULL )
    {
        if ( DestroyFunc != NULL )
        {
            UINT i;
            for ( i = 0; i < pTable->uCursorCount; i++ )
            {
                (*DestroyFunc)( pTable->ppData[i] );
            }
        }
        free( pTable->ppData );
        free( pTable );
    }
}

/**	排序表的添加數(shù)據(jù)函數(shù),數(shù)據(jù)被添加到表尾部

	@param	SORTTABLE *pTable - 排序表指針	
	@param	void *pData - 加入的數(shù)據(jù)指針	
	@return	INT (by default) - 成功返回CAPI_SUCCESS, 失敗返回CAPI_FAILED	
*/
INT	SortTable_Add( SORTTABLE *pTable, void *pData )
{
    if ( pTable == NULL || pData == NULL 
        || pTable->uCursorCount >= pTable->uMaxCount )
    {
        return CAPI_FAILED;
    }
    pTable->ppData[pTable->uCursorCount] = pData;
    pTable->uCursorCount += 1;
    
    return CAPI_SUCCESS;
}

/**	排序表的二分查找函數(shù),調(diào)用此函數(shù)前必須對表從小到大排好序

	@param	SORTTABLE *pTable - 排序表指針	
	@param	void *pData - 要查找的匹配數(shù)據(jù)
	@param	COMPAREFUNC CompareFunc - 比較函數(shù)
	@return	void * - 成功返回查到的數(shù)據(jù),失敗返回NULL
*/
void * SortTable_FindData(SORTTABLE *pTable, void *pData, 
                               COMPAREFUNC CompareFunc)
{
    UINT uLow;
    UINT uHigh;
    UINT uMid;

    if ( pTable == NULL || CompareFunc == NULL || pData == NULL 
        || pTable->uCursorCount == 0 )
    {
        return NULL;
    }

    uLow = 0;
    uHigh = pTable->uCursorCount - 1;
    uMid = 0;
    while ( uLow <= uHigh )
    {
        INT nResult;
        uMid = ( uLow + uHigh ) / 2;
        nResult = (*CompareFunc)( pTable->ppData[uMid], pData );
        if ( nResult > 0 )
        {
            uHigh = uMid - 1;
        }
        else if ( nResult < 0 )
        {
            uLow = uMid + 1;
        }
        else
        {
            /* 已經(jīng)發(fā)現(xiàn)了匹配數(shù)據(jù),返回 */
            return pTable->ppData[uMid];
        }
    }

    /* 未找到匹配數(shù)據(jù),返回空指針 */
    return NULL;
}

/**	排序表的二分查找函數(shù),調(diào)用此函數(shù)前必須對表從小到大排好序

	@param	SORTTABLE *pTable - 排序表指針	
	@param	void *pData - 要查找的匹配數(shù)據(jù)
	@param	COMPAREFUNC CompareFunc - 比較函數(shù)
	@return	void * - 成功返回查到的精確數(shù)據(jù)或剛好比要查找的數(shù)據(jù)大的數(shù)據(jù),
                        失敗返回NULL。
*/
void * SortTable_BlurFind(SORTTABLE *pTable, void *pData, 
                               COMPAREFUNC CompareFunc)
{
    UINT uLow;
    UINT uHigh;
    UINT uMid;

    if ( pTable == NULL || CompareFunc == NULL || pData == NULL 
        || pTable->uCursorCount == 0 )
    {
        return NULL;
    }

    uLow = 0;
    uHigh = pTable->uCursorCount - 1;
    uMid = 0;
    while ( uLow <= uHigh )
    {
        INT nResult;
        uMid = ( uLow + uHigh ) / 2;
        nResult = (*CompareFunc)( pTable->ppData[uMid], pData );
        if ( nResult > 0 )
        {
            uHigh = uMid - 1;
        }
        else if ( nResult < 0 )
        {
            uLow = uMid + 1;
        }
        else
        {
            /* 已經(jīng)發(fā)現(xiàn)了匹配數(shù)據(jù),返回 */
            return pTable->ppData[uMid];
        }
    }

    /* 未找到匹配數(shù)據(jù),返回剛好比它大的數(shù)據(jù) */
    return pTable->ppData[uHigh];
}

/**	排序表的按數(shù)組下標(biāo)索引取數(shù)據(jù)函數(shù)

	@param	SORTTABLE *pTable -排序表指針	
	@param	int uId - 數(shù)組下標(biāo)索引	
	@return	void * - 成功返回?cái)?shù)據(jù)指針,如果數(shù)組索引超出排序表當(dāng)前數(shù)據(jù)
                     的范圍則返回NULL
*/
void * SortTable_GetByID( SORTTABLE *pTable, UINT uId )
{
    void    *pData = NULL;

    if ( pTable != NULL )
    {
        if ( uId < pTable->uCursorCount )
        {
            pData = pTable->ppData[uId];
        }
    }
    return pData;
}

/**	排序表的排序函數(shù)

	@param	SORTTABLE *pTable -排序表指針	
	@param	COMPAREFUNC CompareFunc -數(shù)據(jù)比較函數(shù)	
	@return	INT -xxxx	
*/
INT SortTable_Sort(SORTTABLE *pTable, COMPAREFUNC CompareFunc)
{
    SortTable_QuickSort(pTable, 0, 
        pTable->uCursorCount - 1, CompareFunc);
    return CAPI_SUCCESS;
}

/**	排序表的快速排序劈開函數(shù),將給定范圍數(shù)據(jù)按指定數(shù)據(jù)劈成兩部分,
    一部分全部小于指定數(shù)據(jù),另一部分全部大于指定數(shù)據(jù)
    指定數(shù)據(jù)取給定范圍排序表中的第一個(gè)數(shù)據(jù)

	@param	SORTTABLE *pTable -排序表指針	
	@param	UINT uStart - 表中開始位置	
	@param	UINT uEnd - 表中結(jié)束位置	
	@param	COMPAREFUNC CompareFunc - 數(shù)據(jù)比較函數(shù)	
	@return	UINT - 指定數(shù)據(jù)在表中的位置,即它的數(shù)組下標(biāo)	
*/
static UINT SortTable_Split(SORTTABLE *pTable, UINT uStart, UINT uEnd,
                     COMPAREFUNC CompareFunc)
{
    void *pSelData;
    UINT uLow;
    UINT uHigh;

    uLow = uStart;
    uHigh = uEnd;

    pSelData = pTable->ppData[uLow];
    while ( uLow < uHigh )
    {
        while ( (*CompareFunc)(pTable->ppData[uHigh], pSelData) > 0 
            && uLow != uHigh )
        {
            --uHigh;
        }
        if ( uHigh != uLow )
        {
            pTable->ppData[uLow] = pTable->ppData[uHigh];
            ++uLow;
        }

        while ( (*CompareFunc)( pTable->ppData[uLow], pSelData ) < 0
            && uLow != uHigh )
        {
             ++uLow;
        }
        if ( uLow != uHigh )
        {
            pTable->ppData[uHigh] = pTable->ppData[uLow];
            --uHigh;
        }
    }
    pTable->ppData[uLow] = pSelData;

    return uLow;
}

/**	快速排序算法的使用棧的非遞歸算法函數(shù)

	@param	SORTTABLE *pTable - 排序表指針	
	@param	UINT uStart - 表中的要排序數(shù)據(jù)區(qū)間的起點(diǎn),為數(shù)組下標(biāo)	
	@param	UINT uEnd - 表中要排序數(shù)據(jù)區(qū)間的終點(diǎn),為數(shù)組下標(biāo)	
	@param	COMPAREFUNC CompareFunc - 數(shù)據(jù)比較函數(shù)	
	@return	void - 無 	
*/
void SortTable_QuickSort2(SORTTABLE *pTable, UINT uStart, UINT uEnd, 
                        COMPAREFUNC CompareFunc)
{
    STACK   *pStack;
    UINT    uLow;
    UINT    uHigh;
    UINT    uMid;

    uLow = uStart;
    uHigh = uEnd;

    pStack = Stack_Create(uHigh - uEnd);

    (void)Stack_Push(pStack, (void *)uLow);
    (void)Stack_Push(pStack, (void *)uHigh);

    while ( !Stack_IsEmpty(pStack) )
    {
        uHigh = (UINT)Stack_Pop(pStack);
        uLow = (UINT)Stack_Pop(pStack);
        if ( uLow < uHigh )
        {
            uMid = SortTable_Split(pTable, uLow, uHigh, CompareFunc );
            if ( uMid > uLow )
            {
                (void)Stack_Push(pStack, (void *)uLow );
                (void)Stack_Push(pStack, (void *)(uMid - 1 ));
            }
            if ( uHigh > uMid )
            {
                (void)Stack_Push(pStack, (void *)(uMid + 1) );
                (void)Stack_Push(pStack, (void *)uHigh);
            }
        }
    }
    Stack_Destroy(pStack, NULL);
}

/**	排序表的快速排序函數(shù),不使用棧調(diào)用的非遞歸算法
    將指定區(qū)間的數(shù)據(jù)用快速排序算法排好

	@param	SORTTABLE *pTable - 排序表指針	
	@param	UINT uStart - 要排序的區(qū)間起點(diǎn)	
	@param	UINT uEnd - 要排序的區(qū)間終點(diǎn)		
	@param	COMPAREFUNC CompareFunc - 數(shù)據(jù)比較函數(shù)	
	@return	void - 無	
*/
void SortTable_QuickSort(SORTTABLE *pTable, UINT uStart, UINT uEnd, 
                        COMPAREFUNC CompareFunc)
{
    UINT   *puStack;
    UINT    uStackTop;
    UINT    uLow;
    UINT    uHigh;
    UINT    uMid;

    if ( uEnd - uStart < 1 )
    {
        return;
    }

    uLow = uStart;
    uHigh = uEnd;

    puStack = (UINT *)malloc((uHigh - uLow + 1) * sizeof(UINT));
    if ( puStack == NULL )
    {
        return;
    }
    uStackTop = 0;

    puStack[uStackTop] = uLow;
    ++uStackTop;
    puStack[uStackTop] = uHigh;
    ++uStackTop;

    while ( uStackTop != 0 )
    {
        --uStackTop;
        uHigh = puStack[uStackTop];

        --uStackTop;
        uLow = puStack[uStackTop];
        
        if ( uLow < uHigh )
        {
            uMid = SortTable_Split(pTable, uLow, uHigh, CompareFunc );
            if ( uMid - uLow > uHigh - uMid )
            {
                puStack[uStackTop] = uLow;
                ++uStackTop;
                puStack[uStackTop] = uMid - 1;
                ++uStackTop;
                if ( uHigh > uMid )
                {
                    puStack[uStackTop] = uMid + 1;
                    ++uStackTop;
                    puStack[uStackTop] = uHigh;
                    ++uStackTop;
                }            
            }
            else
            {
                puStack[uStackTop] = uMid + 1;
                ++uStackTop;
                puStack[uStackTop] = uHigh;
                ++uStackTop;
                if ( uMid > uLow )
                {
                    puStack[uStackTop] = uLow;
                    ++uStackTop;
                    puStack[uStackTop] = uMid - 1;
                    ++uStackTop;
                }
            }

        }
    }
    free( puStack );
}

/**	排序表的快速排序函數(shù),將指定區(qū)間的數(shù)據(jù)用快速排序算法排好

	@param	SORTTABLE *pTable - 排序表指針	
	@param	UINT uStart - 要排序的區(qū)間起點(diǎn)	
	@param	UINT uEnd - 要排序的區(qū)間終點(diǎn)		
	@param	COMPAREFUNC CompareFunc - 數(shù)據(jù)比較函數(shù)	
	@return	void - 無	
*/
void SortTable_QuickSort3(SORTTABLE *pTable, UINT uStart, UINT uEnd, 
                        COMPAREFUNC CompareFunc)
{
    UINT uMid = SortTable_Split(pTable, uStart, uEnd, CompareFunc );
    if ( uMid > uStart )
    {
        SortTable_QuickSort3(pTable, uStart, uMid - 1, CompareFunc);
    }

    if ( uEnd > uMid )
    {
        SortTable_QuickSort3(pTable, uMid + 1, uEnd, CompareFunc);
    }
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品一区二区91| 一区二区三区精品在线| 喷白浆一区二区| 91精品国产91热久久久做人人| 亚洲福中文字幕伊人影院| 欧美猛男gaygay网站| 日韩福利电影在线观看| 日韩精品一区二区三区swag | 一本色道久久综合亚洲aⅴ蜜桃| 国产精品精品国产色婷婷| 91丨九色丨尤物| 久久99精品久久久久婷婷| 日韩欧美国产高清| 成人一级片网址| 亚洲精品国产a久久久久久| 欧美日韩在线三区| 久久国产人妖系列| 国产精品素人视频| 欧美影视一区二区三区| 美腿丝袜亚洲综合| 久久久影视传媒| 在线看国产一区| 久久成人免费电影| 国产精品国产a| 在线播放国产精品二区一二区四区| 日本aⅴ免费视频一区二区三区 | 久久久久久久综合狠狠综合| eeuss鲁片一区二区三区在线观看| 亚洲欧美一区二区不卡| 欧美精品视频www在线观看 | 国产成人午夜视频| 洋洋成人永久网站入口| 精品国产乱码久久久久久1区2区 | 国产欧美日韩卡一| 欧美在线观看视频一区二区 | 91精品国产综合久久久蜜臀粉嫩| 激情综合网天天干| 一区二区三区中文字幕精品精品 | 亚洲成a人片综合在线| 久久久99免费| 欧美人妖巨大在线| 99久久久久免费精品国产| 日韩精品成人一区二区三区| 综合色中文字幕| 日韩欧美成人激情| 欧美日本在线播放| 色素色在线综合| 久久草av在线| 一区二区三区色| 国产亚洲美州欧州综合国| 91精品久久久久久久久99蜜臂| 99久久国产综合精品麻豆| 蜜臀av一区二区在线免费观看| 一区二区三区在线视频播放| 国产欧美日韩卡一| 26uuu色噜噜精品一区| 日韩午夜激情av| 欧洲亚洲国产日韩| 99久久免费国产| 成+人+亚洲+综合天堂| 国产一二精品视频| 久久精品国产精品亚洲红杏| 亚洲一区国产视频| 亚洲一区二区三区精品在线| 亚洲欧洲综合另类| 亚洲美女在线一区| 亚洲婷婷国产精品电影人久久| 久久久av毛片精品| 国产日韩欧美精品在线| 久久人人爽爽爽人久久久| 欧美一级在线视频| 欧美一区二区三区视频在线 | 精品日韩一区二区三区免费视频| 欧美三级电影在线看| 91国偷自产一区二区开放时间 | 国产一区二区日韩精品| 美国毛片一区二区| 精品在线一区二区三区| 久久99精品久久久| 久久成人免费电影| 韩国精品久久久| 国产一区二区三区美女| 粉嫩在线一区二区三区视频| 丰满少妇在线播放bd日韩电影| 国产精品系列在线播放| 国产成人亚洲综合a∨猫咪| 豆国产96在线|亚洲| www.在线欧美| 在线观看视频一区二区欧美日韩| 欧美色欧美亚洲另类二区| 欧美一区午夜精品| 久久欧美一区二区| 中文字幕人成不卡一区| 亚洲精品国产视频| 亚洲18影院在线观看| 久久精品国产第一区二区三区| 国产美女视频91| eeuss鲁一区二区三区| 欧美性大战xxxxx久久久| 欧美成人精品二区三区99精品| 久久久午夜精品理论片中文字幕| 国产精品国产三级国产a| 午夜影视日本亚洲欧洲精品| 青青草国产精品亚洲专区无| 国产福利不卡视频| 色视频成人在线观看免| 91精品国产免费久久综合| 久久你懂得1024| 一区二区三区四区五区视频在线观看| 视频一区二区不卡| 成年人国产精品| 555www色欧美视频| 中文字幕精品综合| 三级不卡在线观看| 懂色中文一区二区在线播放| 欧美性猛交xxxxxx富婆| 日韩欧美自拍偷拍| 亚洲欧美日韩国产一区二区三区 | 亚洲超碰97人人做人人爱| 久久99九九99精品| 96av麻豆蜜桃一区二区| 欧美一区二区三区影视| 亚洲另类春色校园小说| 九九精品一区二区| 欧洲av在线精品| 久久久不卡影院| 肉丝袜脚交视频一区二区| av一区二区三区在线| 精品国产一区二区在线观看| 亚洲精品乱码久久久久久| 国产精品一区三区| 在线电影欧美成精品| 一区在线播放视频| 国产亚洲精品bt天堂精选| 午夜日韩在线观看| 国产成人综合自拍| 日韩一区二区在线看| 中文乱码免费一区二区| 成人免费黄色大片| 国产精品一区二区三区99| 欧美私模裸体表演在线观看| 欧美国产综合一区二区| 日韩av网站在线观看| 在线视频你懂得一区二区三区| 国产亚洲精品7777| 免费成人小视频| 欧美曰成人黄网| 亚洲女同ⅹxx女同tv| 成人免费看黄yyy456| 久久综合国产精品| 免费人成网站在线观看欧美高清| 日本高清不卡aⅴ免费网站| 欧美激情综合在线| 国产美女一区二区三区| 精品福利在线导航| 蜜桃视频第一区免费观看| 欧美日韩国产另类一区| 一区二区免费在线| 欧美日韩国产高清一区二区三区| 国产精品国产三级国产aⅴ入口| 色婷婷亚洲综合| 色婷婷久久综合| 中文字幕色av一区二区三区| 国产成人在线视频网站| 欧美精品一区二区三| 国内一区二区视频| 精品国产乱码久久久久久久| 国产在线精品国自产拍免费| 精品成人一区二区三区四区| 精品中文av资源站在线观看| 久久亚洲免费视频| 国精产品一区一区三区mba视频| 日韩欧美色电影| 激情六月婷婷久久| 久久精品男人的天堂| 高清久久久久久| 最新热久久免费视频| 91啪亚洲精品| 亚洲国产另类av| 91麻豆精品国产91| 毛片不卡一区二区| 久久一区二区三区国产精品| 国产精品亚洲午夜一区二区三区| 久久综合精品国产一区二区三区| 国产精品99久久久久| 国产精品乱码一区二区三区软件| 99视频一区二区三区| 有坂深雪av一区二区精品| 欧美性视频一区二区三区| 日韩高清国产一区在线| 久久久电影一区二区三区| 91亚洲国产成人精品一区二三 | 日韩电影免费在线观看网站| 日韩视频一区二区在线观看| 国产精品88av| 亚洲欧美偷拍三级| 精品美女被调教视频大全网站| 国产精品一区三区| 久久久久国产精品麻豆| 石原莉奈在线亚洲三区|