アニメ!アニメ!

2016年1月10日日曜日

C言語 クイックソート(配列要素の並び替え) - stdlib.h - [ qsort ]

#include <stdio.h>
#include <stdlib.h>
#include <time.h>

typedef struct{
int a;
int b;
int c;
}TEST;

int comp(const void*c1,const void*c2);

int main(void)
{
int i;
TEST base[10];

/*乱数の生成*/
srand((unsigned int)time(NULL));

for(i = 0;i<10;i++){
    base[i].a = rand() % 100;   /* 0~99の乱数 */
    base[i].b = rand() % 100;
    base[i].c = rand() % 100;
    printf( "%d\t", base[i].a );
    printf( "%d\t", base[i].b );
    printf( "%d\t", base[i].c );
    printf( "\n" );
  }

/*TEST構造体のbを基準にソート*/
printf("\n--TEST構造体のbを基準にソート--\n\n");
qsort(base,10, sizeof(TEST),comp);

/* ソート後のデータを表示*/
for(i=0;i<10;i++){
    printf( "%d\t", base[i].a );
    printf( "%d\t", base[i].b );
    printf( "%d\t", base[i].c );
    printf( "\n" );
  }

  return 0;
}

/* 比較関数 */
int comp( const void *c1, const void *c2 )
{
  TEST test1 = *(TEST *)c1;
  TEST test2 = *(TEST *)c2;

  int tmp1 = test1.b;   /* b を基準とする */
  int tmp2 = test2.b;

  return tmp1 - tmp2;
}
C言語 クイックソート(配列要素の並び替え) - stdlib.h - [ qsort ] | 勇躍のゴミ箱
http://simd.jugem.jp/?eid=114

0 件のコメント:

コメントを投稿