質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Q&A

解決済

1回答

1572閲覧

qsortを用いた構造体の並べ替え

kelt22

総合スコア46

C

C言語は、1972年にAT&Tベル研究所の、デニス・リッチーが主体となって作成したプログラミング言語です。 B言語の後継言語として開発されたことからC言語と命名。そのため、表記法などはB言語やALGOLに近いとされています。 Cの拡張版であるC++言語とともに、現在世界中でもっとも普及されているプログラミング言語です。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

0グッド

0クリップ

投稿2020/08/18 16:06

質問

qsortを使い構造体を並べ直したいのですが、
qsort(S,3,sizeof(Shop),compareWeight);
qsort(&S[i-count],count,sizeof(Shop),compareType);の部分で構造体の値がすべて同じなのでcompareWeight関数、compareType関数の返却値が常に0になり、そのままの順番で構造体を返してほしいのですが、1つずつ前に順番が入れ替わってしまいます。解説お願いします。

該当のソースコード

c

1#include <stdio.h> 2#include <stdlib.h> 3#include <string.h> 4typedef struct{ 5 int price; 6 int weight; 7 char type[20]; 8 int date; 9 char name[21]; 10}Shop; 11 12int compareWeight(const void *a,const void *b){ 13 Shop *A=(Shop *)a; 14 Shop *B=(Shop *)b; 15 return A->weight-B->weight; 16} 17int compareType(const void *a,const void *b){ 18 Shop *A=(Shop *)a; 19 Shop *B=(Shop *)b; 20 return strcmp(A->type,B->type); 21} 22int main(void){ 23 int i,n; 24 Shop S[3]={{1,10,"A",1,"a"}, 25 {1,10,"A",2,"a"}, 26 {1,10,"A",3,"a"},}; 27 qsort(S,3,sizeof(Shop),compareWeight); 28 for(i=0;i<3;i++){ 29 printf("%d %d %s %d %s\n",S[i].price,S[i].weight,S[i].type,S[i].date,S[i].name); 30 } 31 int count=1; 32 for(i=1;i<3;i++){ 33 if(S[i-1].weight==S[i].weight){ 34 count++; 35 }else{ 36 qsort(&S[i-count],count,sizeof(Shop),compareType); 37 count=1; 38 } 39 } 40 if(count!=1){ 41 qsort(&S[i-count],count,sizeof(Shop),compareType); 42 } 43 44 for(i=0;i<3;i++){ 45 printf("%d %d %s %d %s\n",S[i].price,S[i].weight,S[i].type,S[i].date,S[i].name); 46 } 47 return 0; 48} 49

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

ソートアルゴリズムには様々な種類があり、大きな分類として「安定なソート」と「不安定なソート」に分けられます。 安定なソートというのは大きさが同じ場合に元の順序を維持するソートで、不安定なソートは元の順序を維持することを保証しないソートです。

そして C の標準ライブラリが提供する qsort は不安定なソートです。 なので、質問者の事例では qsort はそういうものですというのが端的な回答です。

簡単な回避方法としては構造体に連番を格納するメンバを用意しておいてソート前に連番をいれておき、値が同じ場合には連番で順序付けをするようにすれば qsort でも安定なソートは可能です。

投稿2020/08/18 17:52

SaitoAtsushi

総合スコア5684

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

kelt22

2020/08/19 02:29

不安定なソートと安定なソートがあるんですね。解説ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問