私が取り組んでいるプログラムは、ファイルを受け取り、1行ずつ解析し、各行をuint32_tに変更して配列に追加します。そこからqsort()で配列をソートすることになっています。 私は自分のプログラムを書いていましたが、どうすればいいはずだと思いましたが、コードをテストすると、uint32_tsはすべて同じ値であると言います。これは、文字列をuint32_tに変更すると間違いがあるためですか? strtoulを使う方が良いでしょうか? 最後に、私のqsortの実装は正しいですか? (これは、コンパイルし、それが物事をソートしているが、私はuint_32へのコンバージョンは明らかに間違っていますので、わからないことを言って とにかく、ここのコードです:。qsortを使用して符号なし整数をソート
int main(int argc, char* argv[]){
char const* const fileName = argv[1];
FILE* file = fopen(fileName, "r"); // should check the result
char line[256];
uint32_t parArray[256];
int compar(const void *a, const void *b){
const unsigned long long *x = a, *y = b;
if(*x > *y)
return 1;
else
return(*x < *y) ? -1: 0;
}
int lineCounter = 0; // starts at 0 for the array
while(fgets(line, sizeof(line), file)){
// parse all info here
uint32_t t = (uint32_t) line;
// build the array
parArray[lineCounter]=t;
lineCounter++;
printf("Original: %s, Unsigned Int: %u\n", line,t);
}
qsort(&parArray[0],lineCounter+1,sizeof(uint32_t*),compar);
int i;
for(i=0;i<lineCounter;i++){
printf("%u\n",parArray[i]);
}
return 0;
}
別の関数(ここで 'main'の中の' compar')内で関数を定義することはgcc拡張です。コードを移植したい場合は、これを使用しないでください。 'main'の前に' compar'の定義を移動してください。 –