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

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

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

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

Q&A

1回答

717閲覧

qsortを使わずにフリガナを昇順にソート

ikedarairama2

総合スコア14

C

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

Eclipse

Eclipseは、IBM社で開発された統合開発環境のひとつです。2001年11月にオープンソース化されました。 たくさんのプラグインがあり自由に機能を追加をすることができるため、開発ツールにおける共通プラットフォームとして位置づけられています。 Eclipse自体は、Javaで実装されています。

0グッド

0クリップ

投稿2019/02/15 09:59

前提・実現したいこと

構造体を使って名前とフリガナと得点を表示しフリガナを昇順に表示したいです。c言語でエクリプスを使ってます。qsort関数を使わずにこのコードと同じ結果を得たいのですがどうしても分かりません。お力を貸してください。

発生している問題・エラーメッセージ

エラーメッセージ

該当のソースコード

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
typedef struct{
char name[30];
char furigana[30];
int score;
}Person;
int Furi(const Person *x,const Person *y){
return strcmp(x->furigana,y->furigana);
}
int Average(const Person *x,int no){
int i,y=0;
for(i = 0;i < no;i++){
y += x[i].score;
}
return y / no;
}
void print_Person(const Person x[],int no){
int i;
for(i = 0;i < no;i++){
printf("%-10s %10s %3d点\n",x[i].name,x[i].furigana,x[i].score);
}
}
int main (void){
Person x[] = {{"田辺 博之","タナベ ヒロユキ", 50},
{"鈴木 次郎","スズキ ジロウ", 78},
{"佐藤 卓","サトウ スグル", 95},
{"山田 拓郎","ヤマダ タクロウ", 55},
{"阿部 新之助","アベ シンノスケ", 70},
{"安藤 弘美","アンドウ ヒロミ",100},
{"木下 陽介","キノシタ ヨウスケ", 35},
{"小田 華","オダ ハナ", 70},
{"篠原 由美","シノハラ ユミ",100},
{"斎藤 巧","サイトウ タクミ", 60},
{"佐藤 大地","サトウ ダイチ",100},
};
int nx = sizeof(x) / sizeof(x[0]);
puts("ソート前");
print_Person(x,nx);

qsort(x,nx,sizeof(Person),(int(*)(const void *,const void *))Furi); puts("\nフリガナ昇順ソート後"); print_Person(x,nx); Average(x,nx); printf("平均点は%d点",Average(x,nx)); return 0;

}

c言語
ソースコード

### 試したこと ここに問題に対して試したことを記載してください。 ### 補足情報(FW/ツールのバージョンなど) ここにより詳細な情報を記載してください。

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

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

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

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

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

LouiS0616

2019/02/15 10:08

要するにソート関数を自作したいのですね? 調べればそれなりの情報が引き出せると思いますが、何か試したことは無いのでしょうか?
guest

回答1

0

まずは ここ を読んで、クイックソート以外のソートにはどんなものがあるのか、どういう原理なのかを調べてみましょう。

クイックソートはほとんどの場合高速に動作するので、クイックソート以外を実装する理由ってあまりないんですが……(クイックソートは非安定なので、安定ソートが必要な場合は自作する必要がありますが)

投稿2019/02/15 10:14

tacsheaven

総合スコア13703

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問