この問題の番号の並び替えがどうしても分かりません。とき方を教えてください。
問題:nこの学生番号と音楽の点数からなる成績データを入力し、成績の順にデータを並び替えるプログラムを作りなさい。
入力 出力
10 ソート前データ
1 56 番号 音楽
2 47 1 56
3 85 2 47
4 57 3 85
5 96 4 57
6 75 5 96
7 81 6 75
8 31 7 81
9 50 8 31
10 76 9 50
10 76
ソート後データ
番号 音楽
5 96
3 85
7 81
10 76
6 75
・ ・
・ ・
(省略)
大変だとは思いますが、お願いします。
No.5ベストアンサー
- 回答日時:
No.4です。
ミスがありました。すみません。ご迷惑を掛けたNo.1さんにお詫びし訂正します。
>No.1の方の回答に補足します。
>i,jをループ用変数とし
>i=0~n-1 nはデータ行数
>j=i+1~n
これではうまくソートが出来ません。n-1はn-2のはずですね。これは基本選択法です。
バブルソート(隣接交換法)なら
i=n-2~0,-1
j=0~i
で (j) と (j+1) を比べて逆転を入れ替えます。
皆さんありがとうございました!自分で考えていたところ解答が分かりましたので報告しておきます。なお、ポイントは、特に一生懸命考えてくれたと思う方に方に差し上げようと思います。
<解答>
#include<stdio.h>
void main(void){
int d[100],c[100],n,a[100],i,j,x,y,max;
printf("n:");
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d %d",&a[i],&d[i]); }
printf("ソート前データ\n");
printf("番号 音楽\n");
for(i=0;i<n;i++) printf("%d %2d\n",a[i],d[i]);
for(i=0;i<n-1;i++){
max=i;
for(j=i+1;j<n;j++)
if(d[max]<d[j]) {max=j; }
x=d[i]; d[i]=d[max]; d[max]=x;
y=a[i]; a[i]=a[max]; a[max]=y;
}
printf("\nソート後データ\n");
printf("番号 音楽\n");
for(i=0;i<n;i++){
printf("%2d %2d\n",a[i],d[i]);
}}
No.4
- 回答日時:
No.1の方の回答に補足します。
>i,jをループ用変数とし
>i=0~n-1 nはデータ行数
>j=i+1~n
これではうまくソートが出来ません。これはソートでなく総当りのループです。
正しくは
i=n-1~0,-1
j=0~i
で (j) と (j+1) を比べて逆転を入れ替えます。
これはバブルソート(隣接交換法)です。
No.3
- 回答日時:
こんなのでどうでしょうか?
#include <stdio.h>
#include <stdlib.h>
typedef struct{
intnumber;
intresult;
}DATA;
//qsort用比較関数
int int_cmp( const void* _data1, const void* _data2 )
{
const DATA*cmp1 = (const DATA*)_data1;
const DATA* cmp2 = (const DATA*)_data2;
int sort;//両要素の差
sort = cmp2->result - cmp1->result;
if(sort != 0)return sort;
returncmp2->result - cmp1->result;
}
//main関数
int main(void){
DATA_data[10];
inti;
charbuf[256];
for(i = 0; i < 10; i++){
printf("学生番号を入力してください\n");
fgets(buf, 256, stdin);
_data[i].number = atoi(buf);
printf("成績を入力してください\n");
fgets(buf, 256, stdin);
_data[i].result = atoi(buf);
}
//sort
qsort( _data, sizeof(_data) / sizeof(DATA), sizeof(DATA), int_cmp );
for(i = 0; i < 10; i++){
printf("学生番号 = %d 成績 = %d\n", _data[i].number, _data[i].result);
}
(void)getchar();
return 0;
}
qsortを使っています。
検索エンジンでqsortとすると関数の詳細が出ますので、
解説はそれをご参考に…。
ただこれって構造体を扱うので、
10個程度なら問題ないのですが、
1万とか大きな数になると問題が大きいのですよね…(^^;。
構造体の交換に時間がかかってしまいますので…。
本当は各要素のポインタの配列をもう一つ用意して、
構造体ではなくそのポインタをソートすればいいのですが、
複雑になるのでやめました。
勉強をするなら、そちらも学ばれたほうが
後々役に立ちますよ(^0^)/
この回答への補足
わざわざ解答していただきありがとうございます.しかし、複雑過ぎてよく分かりません。僕の考えているプログラムを載せておきます。
include<stdio.h>
void main(void){
int d[100],c[100],n,a[100],i,j,x,max;
printf("n:");
scanf("%d",&n);
for(i=0;i<n;i++){
scanf("%d %d",&a[i],&d[i]); }
printf("ソート前データ\n");
printf("番号 音楽\n");
for(i=0;i<n;i++) printf("%d %2d\n",a[i],d[i]);
for(i=0;i<n-1;i++){
max=i;
for(j=i+1;j<n;j++)
if(d[max]<d[j]) {max=j; }
x=d[i]; d[i]=d[max]; d[max]=x;
}
printf("\nソート後データ\n");
printf("番号 音楽\n");
for(i=0;i<n;i++){
printf(" %2d\n",d[i]);
}
}
このプログラムを少しだけ修正(番号の出力)すればうまくいくと思っています。すいませんが他の方もこのプログラムにあった解法をしてくれればうれしいのですが・・・。
No.2
- 回答日時:
調べる方針を書いてみますので参考にしてください。
まず、学生番号と点数を2次元配列に格納して扱います。
(ここでは配列名をAをします)
A11=1(学生番号) A12=56(点数)
A21=2 A22=47
A31=3 A32=85
……
そして、その二次元配列の一つ目の添え字(A21なら2の方の添え字)
だけを考えて、ソートアルゴリズムを使用します。
アルゴリズムはバブルソートでもクイックソートでも
ヒープソートでもかまいません。
(これはプログラミング関係の入門書をみれば
どれかが載っています)
入れ替えのときに、学生番号の方の一つ目の添え字だけでなく、
点数の方の一つ目の添え字も入れ替えるのを忘れないように
してやれば完成です。
No.1
- 回答日時:
ソートアルゴリズムもいろいろありますが、単純な物でよければ次のようにすればいかがでしょう。
データをd(n,2)に読み込みます。
d(n,0)が番号、d(n,1)が音楽の点数とします。
i,jをループ用変数とし
i=0~n-1 nはデータ行数
j=i+1~n
比較式で d(i,1)とd(j,1)を比較しd(j,1)の方が大きければ d(i,1)とd(j,1),d(i,0)とd(j,0)をそれぞれ入れ替える。
ループが終われば順番に並んでいるはずです。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- Excel(エクセル) 【エクセル】並び替えからの並び替え方法 7 2022/07/22 09:46
- Excel(エクセル) 結合セルのソートについて 5 2022/04/22 11:57
- Excel(エクセル) エクセルでキーリストからデータを取り出して1枚1枚印刷するには? 11 2022/06/27 09:52
- Excel(エクセル) 関数EXACT(文字列,文字列)とexcelVBA 3 2022/04/14 15:07
- 格安スマホ・SIMフリースマホ sim移行 4 2022/11/29 14:03
- その他(プログラミング・Web制作) 入力フォームへ、データを自動的に入力するプログラム。どうやって作る? 4 2023/01/16 10:24
- Excel(エクセル) マクロか関数で処理したいのですが、教えて頂けませんか。 8 2022/10/31 15:18
- Excel(エクセル) Excelマクロ 差分抽出の方法が知りたいです。 2 2023/03/07 13:25
- C言語・C++・C# C言語 プログラミング 4 2022/05/22 11:53
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・プリン+醤油=ウニみたいな組み合わせメニューを教えて!
- ・タイムマシーンがあったら、過去と未来どちらに行く?
- ・遅刻の「言い訳」選手権
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・ハマっている「お菓子」を教えて!
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
構造体配列のソート
-
C言語・要素除去
-
C++ 入力した3つのint型の整数...
-
VB6でデータを昇順に並べ替える
-
あるディレクトリ内のファイル...
-
C# DataGridView のヘッダーセ...
-
VB.NETでファイル名順にファイ...
-
クイックソート
-
Excel VBAで並べ替えをしたい
-
VBA基本構文の作り方 2列の...
-
GridViewで列のソートを無効に...
-
excel VBA リストビューの行...
-
DataGridViewソート時に先頭行...
-
VB6 2つのListBoxをソート
-
VBScriptで配列のソートをする...
-
配列の問題
-
VBでの画面間のデータの引渡し
-
n番目に大きい数を求めるアル...
-
文字列をソートする方法
-
System.IO.Directory.GetFiles...
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
System.IO.Directory.GetFiles...
-
VB.NETでファイル名順にファイ...
-
C# DataGridView のヘッダーセ...
-
あるディレクトリ内のファイル...
-
C言語・要素除去
-
ファイル名「1.jpg ~10.jpg~...
-
Excelですべての組合せ(重複組...
-
C言語でアナグラムを求めるプロ...
-
2次元配列を複数項目でソートし...
-
C# DataTableの行をソートしてD...
-
DataGridViewソート時に先頭行...
-
n番目に大きい数を求めるアル...
-
DataGridViewの複数列を連動し...
-
VBA基本構文の作り方 2列の...
-
配列の問題
-
10個の整数を入力して小さい順...
-
構造体配列の並べ替え
-
vbでDataTableの抽出コピー
-
リスト構造のソートで悩んでま...
-
excel VBA リストビューの行...
おすすめ情報