quicksort.h

Female celtic vocals, Epic cinematic scores, sweeping orchestral movements, adventure music

July 27th, 2024suno

Lyrics

#pragma once #ifndef ORDERING_DEFINED #define ORDERING_DEFINED typedef enum { Ordering_LessThan = -1, Ordering_Equal = 0, Ordering_GreaterThan = 1, } Ordering; void _null_write_cb(void* userdata, void* loc) { (void)userdata; (void)loc; return; } #endif typedef ptrdiff_t ssize_t; void quicksort_swap(void* write_cb_userdata, char* a, char* b, ssize_t elem_size, void (*write_cb)(void*, void*)) { for (ssize_t i = 0; i < elem_size; i++) { char tmp = a[i]; a[i] = b[i]; b[i] = tmp; } write_cb(write_cb_userdata, (void*)a); write_cb(write_cb_userdata, (void*)b); } ssize_t partition( void* write_cb_userdata, void* cmp_cb_userdata, void* elems_void, ssize_t elem_size, ssize_t low, ssize_t high, void (*write_cb)(void*, void*), Ordering (*cmp_cb)(void*, void*, void*) ) { char* elems = (char*)elems_void; char* pivot = elems+high*elem_size; //quicksort_swap(write_cb_userdata, pivot, elems+high*elem_size, elem_size, write_cb); ssize_t i = low-1; for(ssize_t j = low; j < high; j++) { char* a = elems+j*elem_size; if (cmp_cb(cmp_cb_userdata, a, pivot) <= 0) { i += 1; quicksort_swap(write_cb_userdata, elems + i*elem_size, elems+ j*elem_size, elem_size, write_cb); } } quicksort_swap(write_cb_userdata, elems +(i+1)*elem_size, elems +high*elem_size, elem_size, write_cb); return i+1; } #include <stdlib.h> #include <time.h> int partition_r( void* write_cb_userdata, void* cmp_cb_userdata, void* elems_void, ssize_t elem_size, ssize_t low, ssize_t high, void (*write_cb)(void*, void*), Ordering (*cmp_cb)(void*, void*, void*) ) { char* elems = (char*)elems_void; srand(time(NULL)); int random = low + rand() % (high - low); quicksort_swap(0, elems+random*elem_size, elems+high*elem_size, elem_size, _null_write_cb); return partition(write_cb_userdata, cmp_cb_userdata, elems_void, elem_size, low, high, write_cb, cmp_cb); } void quicksort_impl( void* write_cb_userdata, void* cmp_cb_userdata, void* elems, ssize_t elem_size, ssize_t elem_low, ssize_t elem_high, void (*write_cb)(void*, void*), Ordering (*cmp_cb)(void*, void*, void*) ) { if (elem_low < elem_high) { ssize_t index = partition_r(write_cb_userdata, cmp_cb_userdata, elems, elem_size, elem_low, elem_high, write_cb, cmp_cb); quicksort_impl(write_cb_userdata, cmp_cb_userdata, elems, elem_size, elem_low, index-1, write_cb, cmp_cb); quicksort_impl(write_cb_userdata, cmp_cb_userdata, elems, elem_size, index+1, elem_high, write_cb, cmp_cb); } } void quicksort( void* write_cb_userdata, void* cmp_cb_userdata, void* elems, size_t elem_size, size_t elem_len, void (*write_cb)(void*, void*), Ordering (*cmp_cb)(void*, void*, void*) ) { if (!write_cb) { write_cb=_null_write_cb; } quicksort_impl(wri

Recommended

賞花密友
賞花密友

indie pop, Hong Kong, chill, groovy rap, love song, cantonpop

Space Cowboy
Space Cowboy

Synthwave Electronic Epic Music Cinematic Futuristic Adventure Sci-Fi Instrumental Synthpop Banjo, country

Beyond the Veil
Beyond the Veil

Neo-Classical, Orchestral, Instrument-core, clear voice, female vocals

Николь
Николь

man voice, driving rhytm, anthem , edm, acoustic guitar, rif

Anarchy Pulse
Anarchy Pulse

female vocalist,male vocalist,rock,alternative metal,post-hardcore,aggressive

Satyajeet's Journey
Satyajeet's Journey

melodic acoustic country

Shine of Our Love
Shine of Our Love

Pop Rock, Rock alternativo, Pop

Lights Of The Night
Lights Of The Night

Epic power metal, shred guitar, pop vocals

tap-Tap
tap-Tap

16bit , hard , vocaloid

El poder
El poder

bachata dance, romantica, amor, pasion, swing, dance

Летний Рассвет
Летний Рассвет

мягкий акустический пение птиц

Golden Paw in Charleston
Golden Paw in Charleston

country acoustic melodic

Corazón de Madre
Corazón de Madre

female vocalist,bossa nova,jazz,vocal jazz,soul,smooth jazz

Junácká hymna ;-)
Junácká hymna ;-)

symphonic metal

Oblivion’s Fate
Oblivion’s Fate

Medieval Metal, Experimental, progressive, Glam, symphonic