* renamed map to htb
* added qse_awk_findgbl() * added Awk::findGlobal() * began working on red-black tree
This commit is contained in:
94
qse/samples/cmn/rbt.c
Normal file
94
qse/samples/cmn/rbt.c
Normal file
@ -0,0 +1,94 @@
|
||||
#include <qse/cmn/mem.h>
|
||||
#include <qse/cmn/str.h>
|
||||
#include <qse/cmn/rbt.h>
|
||||
#include <qse/cmn/stdio.h>
|
||||
#include <stdlib.h>
|
||||
|
||||
|
||||
#define R(f) \
|
||||
do { \
|
||||
qse_printf (QSE_T("== %s ==\n"), QSE_T(#f)); \
|
||||
if (f() == -1) return -1; \
|
||||
} while (0)
|
||||
|
||||
static qse_rbt_walk_t walk (qse_rbt_t* rbt, qse_rbt_node_t* node, void* ctx)
|
||||
{
|
||||
qse_printf (QSE_T("key = %d, value = %d\n"), node->key, node->value);
|
||||
return QSE_RBT_WALK_FORWARD;
|
||||
}
|
||||
|
||||
static int test1 ()
|
||||
{
|
||||
qse_rbt_t* s1;
|
||||
qse_char_t* x[] =
|
||||
{
|
||||
QSE_T("this is so good"),
|
||||
QSE_T("what the fuck"),
|
||||
QSE_T("do you like it?"),
|
||||
QSE_T("oopsy!")
|
||||
};
|
||||
int i;
|
||||
|
||||
s1 = qse_rbt_open (QSE_MMGR_GETDFL(), 0);
|
||||
if (s1 == QSE_NULL)
|
||||
{
|
||||
qse_printf (QSE_T("cannot open a string\n"));
|
||||
return -1;
|
||||
}
|
||||
|
||||
/*
|
||||
qse_rbt_setcopier (s1, QSE_LDA_COPIER_INLINE);
|
||||
qse_rbt_setkeeper (s1, keeper1);
|
||||
qse_rbt_setscale (s1, QSE_SIZEOF(qse_char_t));
|
||||
*/
|
||||
|
||||
for (i = 0; i < 20; i++)
|
||||
{
|
||||
qse_printf (QSE_T("inserting at %d\n"), i);
|
||||
qse_rbt_insert (s1, i, i * 20);
|
||||
}
|
||||
|
||||
qse_rbt_walk (s1, walk, QSE_NULL);
|
||||
|
||||
for (i = 0; i < 20; i += 2)
|
||||
{
|
||||
qse_printf (QSE_T("deleting %d\n"), i);
|
||||
qse_rbt_delete (s1, i);
|
||||
}
|
||||
|
||||
qse_rbt_walk (s1, walk, QSE_NULL);
|
||||
|
||||
for (i = 0; i < 20; i++)
|
||||
{
|
||||
qse_printf (QSE_T("inserting at %d\n"), i);
|
||||
qse_rbt_insert (s1, i, i * 20);
|
||||
}
|
||||
|
||||
qse_rbt_walk (s1, walk, QSE_NULL);
|
||||
|
||||
qse_rbt_clear (s1);
|
||||
for (i = 20; i > 0; i--)
|
||||
{
|
||||
qse_printf (QSE_T("inserting at %d\n"), i);
|
||||
qse_rbt_insert (s1, i, i * 20);
|
||||
}
|
||||
|
||||
qse_rbt_walk (s1, walk, QSE_NULL);
|
||||
|
||||
for (i = 0; i < 20; i += 3)
|
||||
{
|
||||
qse_printf (QSE_T("deleting %d\n"), i);
|
||||
qse_rbt_delete (s1, i);
|
||||
}
|
||||
|
||||
qse_rbt_walk (s1, walk, QSE_NULL);
|
||||
|
||||
qse_rbt_close (s1);
|
||||
return 0;
|
||||
}
|
||||
|
||||
int main ()
|
||||
{
|
||||
R (test1);
|
||||
return 0;
|
||||
}
|
Reference in New Issue
Block a user