quicksort.h

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

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

Empfohlen

Chase the Dream
Chase the Dream

swing brass lively

สบายใจ
สบายใจ

Art rock alternative rock electronica experimental rock, build up

Odyssey
Odyssey

In the vast expanse of the cosmos, a lone spaceship embarks on an epic journey to explore epic prog rock. Male voice.

Hey Diddle Diddle My Cat Can Fiddle
Hey Diddle Diddle My Cat Can Fiddle

Bluegrass, dubstep, banjo, guitar, bass, fiddle, mandolin, piano

私が支配してあげる
私が支配してあげる

city pop breakbeat,upbeat

Bailando Bajo La Lluvia
Bailando Bajo La Lluvia

upbeat tropical cumbia

Abyssal Eureka
Abyssal Eureka

trap, beat, rap, alternative rock, male voice

Riverboat Blues
Riverboat Blues

new orleans jazz band, gypsy jazz, blues

Don moen
Don moen

female gospel singer

时光不辜负
时光不辜负

emotional,female voice

Vibin'
Vibin'

futuristic salsa bass

Amour fané
Amour fané

French pop 1960'

Torn in Two
Torn in Two

pop ballad emotional piano-driven

cute cat
cute cat

smooth, pop, beat, electro, lo-fi, electronic , female voice

梦幻泡泡浴
梦幻泡泡浴

folk pop,warm,soothing,happy,film soundtrack

Dancing in the Rain
Dancing in the Rain

2音で作る クラブミックス 男性ボーカル, anime, 英語、xoxo風

Sera
Sera

chill, pop, powerful, rock, synth