我有一個結構數組,我希望按升序排序。排序C中的結構數組
經過對Stack Overflow的大量研究,我發現了sorting members of structure array。
因此,我有以下代碼:
#include <stdio.h>
#include <stdlib.h>
typedef struct StockItem {
int unitPrice;
// ...
} stockItem;
int comparePrice(const void* a, const void* b)
{
stockItem *stockItem1 = (stockItem *) a;
stockItem *stockItem2 = (stockItem *) b;
return stockItem1->unitPrice - stockItem2->unitPrice;
}
int main() {
stockItem stockItem1;
stockItem1.unitPrice = 15;
stockItem stockItem2;
stockItem2.unitPrice = 41;
stockItem stockItem3;
stockItem3.unitPrice = 25;
stockItem stockItems[3] = {stockItem1, stockItem2, stockItem3};
int size = 3;
qsort(stockItems, (size_t) size, sizeof(int), comparePrice);
printf("\n");
for (int i = 0; i < size; i++) {
printf("%d\n", stockItems[i].unitPrice);
}
return 0;
}
然而,這似乎並沒有對數組進行排序。
你會得到什麼輸出? –
什麼是sizeof(int)和sizeof(stockItem)'? – dbush
它只是返回相同的數組,沒有變化 –