2016-04-25 23 views
1

一般クイックソート機能を作成しようとしています。正しく動作していないため、何が問題なのか理解できません。私はそれが一般的なようにしようのないオリジナルのクイックソート機能は、ですが何らかの理由で汎用クイックソートが機能しない

#include <stdlib.h> 
#include <string.h> 
#include <stdio.h> 
#include <stdbool.h> 
#include <assert.h> 

typedef bool (*CmpFunction)(void*, void*); 

    int cmp(const void *c1, const void *c2) 
{ 
    assert(c1 && c2); 
    int a = *(const int*)c1; 
    int b = *(const int*)c2; 
    if (a > b) return 1; 
    if (a < b) return -1; 
    return 0; 
} 

void swap(void *a, void *b, size_t size) { 
    char tmp[size]; 

    memcpy(tmp, a, size); 
    memcpy(a, b, size); 
    memcpy(b, tmp, size); 
} 

    void quick_sort(void* a, int n, int size, CmpFunction cmp) 
{ 
    int b = 1, t = n - 1; 
    if (n < 2) 
     return; 
    swap((char*)a, (char*)a+(n/2)*size, size); 
    char p = *(char*)a; 
    while(b <= t) { 
     while(t >= b && cmp((char*)a + t*size, &p) >= 0) 
     t--; 
     while(b <= t && cmp((char*)a + b*size, &p) < 0) 
     b++; 
     if (b < t) 
     swap((char*)a+size*(b++), (char*)a+size*(t--), size); 
    } 
    swap((char*)a, (char*)a+t*size, size); 
    quick_sort(a, t, size, cmp); 
    n=n-t-1; 
    quick_sort((char*)a + (t + 1)*size, n, size, cmp); 
} 

int main(){ 

    char b[] = {'a','t','b','c','y','s'}; 
    int c[] = {1,4,6,3,5,7}; 
    quick_sort(c, 6, sizeof(c[0]), &cmp); 

    for (int i=0;i<6;i++) 
     printf("%d | ", c[i]); 

    return 0; 
} 
:私はこのメイン()を使用してい

void quick_sort(int a[], int n) 
{ 
    int p, b = 1, t = n - 1; 
    if (n < 2) 
     return; 
    swap(&a[0], &a[n/2]); 
    p = a[0]; 
    while(b <= t) { 
     while(t >= b && a[t] >= p) 
     t--; 
     while(b <= t && a[b] < p) 
     b++; 
     if (b < t) 
     swap(&a[b++], &a[t--]); 
    } 
    swap(&a[0], &a[t]); 
    quick_sort(a, t); 
    n=n-t-1; 
    quick_sort(a + t + 1, n); 
} 

void swap(int *c1, int *c2) 
    { 
     int c = *c1; 
     *c1 = *c2; 
     *c2 = c; 
    } 


ここ は私のコードです

出力は次のようになります:

1, 3, 4, 5, 6, 7 

これは実際にはNOT generic関数を実行するときに得られるものです。私は私のジェネリック(上)関数を実行すると
私はこれを取得:

5 | 1 | 4 | 7 | 6 | 3 | 


あなたのすべては、私が間違っている任意のアイデアがありますか? :)

+0

デバッガを試しましたか?または中間結果を印刷しますか? (またはqsort関数) –

+0

@MohitJainこれらのボイドをすべてデバッグするのは非常に難しいです。 Eclipseは現在の値を表示しません。デバッグする別の方法を知っていますか? –

+0

Google「小さなCコードをデバッグする方法」 –

答えて

-1
#include <stdlib.h> 
#include <string.h> 
#include <stdio.h> 


int integerCompare(const void *c1, const void *c2) // use this to compare int 
{ 
    int a = *(const int*) c1; 
    int b = *(const int*) c2; 
    if (a > b) { 
     return 1; 
    } else if(a < b) { 
     return -1; 
    } else { 
     return 0; 
    } 
} 


int characterCompare(const void *c1, const void *c2) // use this to compare char 
{ 
    char a = *(const int*) c1; 
    char b = *(const int*) c2; 
    if (a > b) { 
     return 1; 
    } else if(a < b) { 
     return -1; 
    } else { 
     return 0; 
    } 
} 



void swap(void *a, void *b, size_t size) { 
    // instead of using an array, use a void pointer and malloc 
    void* tmp = malloc(size); 
    memcpy(tmp, a, size); 
    memcpy(a, b, size); 
    memcpy(b, tmp, size); 
    free(tmp); // free the allocated space 
} 

void quick_sort(void* a, int n, int size, int (*cmp)(const void*, const void*)) 
{ 
    int b = 1; 
    int t = n - 1; 
    if (n < 2) { 
     return; 
    } 
    swap(a, a + (n/2) * size, size); // &a[0] == a 
    // you do not need that p variable .. its value is not being modified 
    while(b <= t) { 
     while(t >= b && cmp(a + t*size, a) >= 0) 
     t--; 
     while(b <= t && cmp(a + b*size, a) < 0) 
     b++; 
     if (b < t) 
     swap(a + size * (b++), a + size * (t--), size); 
    } 
    swap(a, a + t * size, size); 
    quick_sort(a, t, size, cmp); 
    n= n - t - 1; 
    quick_sort(a + (t + 1)*size, n, size, cmp); 
} 

int main() 
{ 
    char b[] = {'a','t','b','c','y','s'}; 
    int c[] = {1,4,6,3,5,7}; 

    quick_sort(c, 6, sizeof(c[0]), &integerCompare); 
    for (int i=0;i<6;i++) { 
     printf("%d | ", c[i]); 
    } 
    printf("\n"); 
    quick_sort(b, 6, sizeof(b[0]), &characterCompare); 
    for (int i=0;i<6;i++) { 
     printf("%c | ", b[i]); 
    } 

    return 0; 
} 
+0

@downvoter私が尋ねることができる場合、コードはあなたのために働いていないのですか? – jboockmann

関連する問題