• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

Sortowanie Błąd

Object Storage Arubacloud
0 głosów
104 wizyt
pytanie zadane 1 stycznia 2016 w C i C++ przez GameFreak Początkujący (450 p.)

Witam. Mam problem z sortowaniem po ID w moim kodzie. Wyskakuje jakiś błąd. Prosiłbym o pomoc. Z góry dzięki!!!

#include <cstdio>
#include <windows.h>
#include <clocale>
#include <cstring>
#include "Utils.h"
#include <cstdlib>
#include <ctime>

typedef int (*CompFuncType)(const void*,const void*);

int CompareDrawnID(const SStudentData *aResult1, const SStudentData *aResult2)
{
    return aResult1->ID - aResult2->ID;
}

void SortResultsByID()
{
    qsort(Students, StudentCount, sizeof(SStudentData), (CompFuncType)CompareDrawnID);
}

struct SStudentData
{
    char *FName;
    char *LName;
    unsigned int ID;
};


int StudentCount = 0;
SStudentData*Students = NULL;


void PrintDatabase()
{
    for(int i=0; i<StudentCount; i++)
        printf("%s | %s | %06d\n",
               Students[i].FName,
               Students[i].LName,
               Students[i].ID);

    printf("\n");
}

void AddRecord()
{
    const unsigned int bufferSize = 256;
    char strBuffer[bufferSize];

    StudentCount++;
    Students = (SStudentData*)realloc(Students, (StudentCount)*sizeof(SStudentData));

    strBuffer[0] = 0;
    GetString(strBuffer, bufferSize-1, "Podaj imie:");
    Students[StudentCount-1].FName = (char*)calloc(strlen(strBuffer)+1,sizeof(char));
    strcpy(Students[StudentCount-1].FName, strBuffer);

    GetString(strBuffer, bufferSize-1, "Podaj nazwisko:");
    Students[StudentCount-1].LName = (char*)calloc(strlen(strBuffer)+1,sizeof(char));
    strcpy(Students[StudentCount-1].LName, strBuffer);

    printf("Podaj nr indeksu:");
    scanf("%d", &(Students[StudentCount-1].ID));
}



int main()
{
    const int answerBufLen = 7;
    char answer[answerBufLen];
    bool exitProgram = false;

    SetCP1250();


    do
    {
        printf("1. Wyswietlenie wszystkich rekordow.\n");
        printf("2. Dodanie rekordu.\n");
        printf("3. Wyjscie z programu.\n\n");
        printf("4. Sortowanie po ID.\n\n");
        printf("5. Sortowanie po nazwisku.\n\n");
        printf("6. Sortowanie po imieniu.\n\n");
        GetString(answer, answerBufLen-1, "Wybierz opcje:");
        if(strcmp(answer,"1")==0)
        {
            PrintDatabase();
        }
        else if(strcmp(answer,"2")==0)
        {
            AddRecord();
        }
        else if(strcmp(answer,"3")==0)
        {
            SortResultsByID();
        }
        /*}
        else if(strcmp(answer,"4")==0)
        {

        }
        else if(strcmp(answer,"5")==0)
        {

        }*/
        else if(strcmp(answer,"6")==0)
        {
            exitProgram = true;
            for(int i=0; i<StudentCount; i++)
            {
                             free(Students[i].FName);
                              free(Students[i].LName);

            }
            free(Students);
        }
        else
        {
            printf("Podano nieprawidlowa opcje.\n");
        }
    }
    while(!exitProgram);

    return 0;
}

 

2 odpowiedzi

0 głosów
odpowiedź 1 stycznia 2016 przez Patryk Krajewski Nałogowiec (26,170 p.)
Ale podaj nam ten błąd.
0 głosów
odpowiedź 1 stycznia 2016 przez Radfler VIP (101,030 p.)
typedef int (*CompFuncType)(const void*,const void*);
 
int CompareDrawnID(const SStudentData *aResult1, const SStudentData *aResult2)
{
    return aResult1->ID - aResult2->ID;
}
 
void SortResultsByID()
{
    qsort(Students, StudentCount, sizeof(SStudentData), (CompFuncType)CompareDrawnID);
}

Absolutnie nie powinieneś rzutować wskaźnika na funkcję (powiedzmy) x na wskaźnik na funkcję y. Wywołanie takiej funkcji prawie zawsze prowadzi do niezidentyfikowanego zachowania. Powinieneś raczej utworzyć funkcję porównującą o takiej deklaracji:

int CompareDrawnID(const void*aResult1, const void*aResult2);

W jej ciele dokonujesz rzutowania wskaźnika z const void* na wskaźnik const SStudentData*, a następnie porównujesz wartości, na które wskazują te wskaźniki.

komentarz 1 stycznia 2016 przez GameFreak Początkujący (450 p.)
a tak bardziej po ludzku ?:D
komentarz 1 stycznia 2016 przez Radfler VIP (101,030 p.)

Zrób taką funkcję:

int CompareDrawnID(const void* lhs, const SStudentData* rhs)
{
    const SStudentData* aResult1 = (const SStudentData*)lhs;
    const SStudentData* aResult2 = (const SStudentData*)rhs;
    return aResult1->ID - aResult2->ID;
}

Po prostu funkcja porównująca musi być dokładnie taka:

int (*)(const void*, const void*);

Mają być dokładnie takie argumenty i typ zwracany. Po prostu w ciele funkcji porównującej zrzutuj wskaźnika z void na typ na który chcesz (w tym przypadku SStudentData). Pozdrawiam! :D

Podobne pytania

0 głosów
1 odpowiedź 152 wizyt
0 głosów
2 odpowiedzi 179 wizyt
pytanie zadane 4 grudnia 2017 w C i C++ przez kappa997 Nowicjusz (230 p.)
0 głosów
2 odpowiedzi 97 wizyt
pytanie zadane 8 maja 2023 w C i C++ przez Janchess Początkujący (480 p.)

92,582 zapytań

141,433 odpowiedzi

319,666 komentarzy

61,966 pasjonatów

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj.

Akademia Sekuraka

Kolejna edycja największej imprezy hakerskiej w Polsce, czyli Mega Sekurak Hacking Party odbędzie się już 20 maja 2024r. Z tej okazji mamy dla Was kod: pasjamshp - jeżeli wpiszecie go w koszyku, to wówczas otrzymacie 40% zniżki na bilet w wersji standard!

Więcej informacji na temat imprezy znajdziecie tutaj. Dziękujemy ekipie Sekuraka za taką fajną zniżkę dla wszystkich Pasjonatów!

Akademia Sekuraka

Niedawno wystartował dodruk tej świetnej, rozchwytywanej książki (około 940 stron). Mamy dla Was kod: pasja (wpiszcie go w koszyku), dzięki któremu otrzymujemy 10% zniżki - dziękujemy zaprzyjaźnionej ekipie Sekuraka za taki bonus dla Pasjonatów! Książka to pierwszy tom z serii o ITsec, który łagodnie wprowadzi w świat bezpieczeństwa IT każdą osobę - warto, polecamy!

...