quicksort.h

Epic cinematic scores, sweeping orchestral movements, heroic themes, and stirring emotional peaks, adventure,

July 27th, 2024suno

歌词

#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

推荐歌曲

Desert Dance
Desert Dance

touchy oriental acoustic vibes arabic bellydance flamenco guitars

Подземельное Путешествие
Подземельное Путешествие

ost, instrumental, electronic (16 bit), chiptune, (dungeon theme 8 bit), orchestra (16 bit), piano

집중!
집중!

repetitive pop

Star of Night "Twinkle Twinkle Little Star":
Star of Night "Twinkle Twinkle Little Star":

jazz & pop .pop .electro. rock. child .beat

Mirage
Mirage

vaporware, futuresynth, soulful female vocals, tech-house

The Nether Empire Song: "Defiant Flames of the Nether"
The Nether Empire Song: "Defiant Flames of the Nether"

This extended version adds more verses, bridges, and instrumental sections to create a powerful and immersive

Whispers from the Abyss
Whispers from the Abyss

Operatic baritones Gothic metal, death/doom metal Operatic baritones Operatic baritones Operatic baritones

Hop on the Magic Llama
Hop on the Magic Llama

Catchy trippy chip tune, phonk

In Your Orbit
In Your Orbit

groovy dream pop synth-heavy

Innovate-Tours
Innovate-Tours

anthemic rap

Syv A
Syv A

electro, electronic, catchy, guitar, female voice

Feuerwerk
Feuerwerk

hard pop

Days Getting Older
Days Getting Older

alternative rock, guitar, anime, sad, emo, emotional

Everyone knows
Everyone knows

deep house, bass, harmonies, female vocals, upbeat, energetic,pop

Fly Beyond the Sky
Fly Beyond the Sky

anime, indie rock, J-rock, acoustic, metal, rock, pop