No.3ベストアンサー
- 回答日時:
ソート(並び替え)の関数としうのを馬鹿正直に汎用のソートアルゴリズムだと考えてしまうと、一気に情報処理の勉強とかをしてないと難しい話になってしまいます。
ソートのアルゴリズムは簡単なのから難しいのまで色々ありますが、問題とされているのは3つのint値なので、配列を比較して効率が云々みたいな本格的なものを求められているのとはちょっと違うのかなと思います。
関数はまぁ理解されたようなので、じゃあ並び替えってどうやったらいいのんというのを考えてみると、3つの数値をそれぞれ比較すればいいだけなので、関数はこんな感じになるでしょうか。
void sort_test3( int i1, int i2, int i3 ) {
int tmp;
//一番目を決める
if( i1 > i2 ) {//一つ目が二つ目より大きい場合は入れ替える
tmp = i2;
i2 = i1;
i1 = tmp;
}
if( i1 > i3 ) {//一つ目が三つ目より大きい場合は入れ替える
tmp = i3;
i3 = i1;
i1 = tmp;
}
//二番目目を決める
if( i2 > i3 ) {//二つ目が三つ目より大きい場合は入れ替える
tmp = i3;
i3 = i2;
i2 = tmp;
}
printf( "%d, %d, %d", i1, i2, i3 );//結果出力
}
まぁ、ここまで書くのがあなたのためになるかは分からないのですが、まるまるコピーしてはい終わりではなく、何やってるかのコメント部分を読んで、どういうロジックが動くのかを想像し、入れ替え(並び替え)の超基本的なやり方を学んでください。
変数の入れ替えは入れ替えたい2つの変数+一時保存の変数の3つを使います。
一時に先に上書きする方の変数を入れて記憶。
一時に記憶させた方の変数にもう片方の変数を入れる。
もう片方の変数に一時記憶の内容を入れる。
です。
そして、3つの数値の並び替えは、まず1位を決定するために「if」条件文にて1と2、1と3つめの数値の大小を比較し、昇順なので1のほうが大きい場合は入れ替えます。
次に2位をきめないといけないので、2と3つめの数値の大小を比較して、2のほうが大きい場合は入れ替えます。
まぁ入門はこんな感じですが、一般的なソートの関数について知りたい場合はバブルソートやクイックソートなどで検索してみてください。
安直にライブラリ使うのも引っかかってしまうかもしれませんが、たしかVisual Studio(無料)のソースの中探せばソート関連の生のアルゴリズムがかかれたソースもあったかと思います。今の配布されてるバージョンでもあるかまでは分かりませんが。
私はライブラリのソートは重い上に融通が利かないので、c++ではクイックソートのアルゴリズムを自己流にしたものを使用しています。
頑張ってください。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
関連するカテゴリからQ&Aを探す
おすすめ情報
- ・漫画をレンタルでお得に読める!
- ・【大喜利】【投稿~11/12】 急に朝起こしてきた母親に言われた一言とは?
- ・好きな和訳タイトルを教えてください
- ・うちのカレーにはこれが入ってる!って食材ありますか?
- ・好きな「お肉」は?
- ・あなたは何にトキメキますか?
- ・おすすめのモーニング・朝食メニューを教えて!
- ・「覚え間違い」を教えてください!
- ・とっておきの手土産を教えて
- ・「平成」を感じるもの
- ・秘密基地、どこに作った?
- ・【お題】NEW演歌
- ・カンパ〜イ!←最初の1杯目、なに頼む?
- ・一回も披露したことのない豆知識
- ・これ何て呼びますか
- ・チョコミントアイス
- ・初めて自分の家と他人の家が違う、と意識した時
- ・「これはヤバかったな」という遅刻エピソード
- ・これ何て呼びますか Part2
- ・許せない心理テスト
- ・この人頭いいなと思ったエピソード
- ・牛、豚、鶏、どれか一つ食べられなくなるとしたら?
- ・あなたの習慣について教えてください!!
- ・ハマっている「お菓子」を教えて!
- ・高校三年生の合唱祭で何を歌いましたか?
- ・【大喜利】【投稿~11/1】 存在しそうで存在しないモノマネ芸人の名前を教えてください
- ・好きなおでんの具材ドラフト会議しましょう
- ・餃子を食べるとき、何をつけますか?
- ・あなたの「必」の書き順を教えてください
- ・ギリギリ行けるお一人様のライン
- ・10代と話して驚いたこと
- ・家の中でのこだわりスペースはどこですか?
- ・つい集めてしまうものはなんですか?
- ・自分のセンスや笑いの好みに影響を受けた作品を教えて
- ・【お題】引っかけ問題(締め切り10月27日(日)23時)
- ・大人になっても苦手な食べ物、ありますか?
- ・14歳の自分に衝撃の事実を告げてください
- ・架空の映画のネタバレレビュー
- ・「お昼の放送」の思い出
- ・昨日見た夢を教えて下さい
- ・ちょっと先の未来クイズ第4問
- ・【大喜利】【投稿~10/21(月)】買ったばかりの自転車を分解してひと言
- ・メモのコツを教えてください!
- ・CDの保有枚数を教えてください
- ・ホテルを選ぶとき、これだけは譲れない条件TOP3は?
- ・家・車以外で、人生で一番奮発した買い物
- ・人生最悪の忘れ物
- ・【コナン30周年】嘘でしょ!?と思った○○周年を教えて【ハルヒ20周年】
- ・あなたの習慣について教えてください!!
- ・都道府県穴埋めゲーム
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
VBA基本構文の作り方 2列の...
-
VB.NETでファイル名順にファイ...
-
数字文字列のソート方法
-
Excelですべての組合せ(重複組...
-
文字列をソートする方法
-
複数キーを利用したソートの仕...
-
配列の問題
-
GridViewで列のソートを無効に...
-
シフトJISのソート
-
偶数奇数の判別!!
-
In Design
-
Excel VBA テキストボックス内...
-
2次元配列を複数項目でソートし...
-
アルゴリズムについて教えてく...
-
構造体配列のソート
-
VB.NETでソートされたデータセ...
-
配列の中身を入れ替える方法を...
-
C# DataGridView のヘッダーセ...
-
C言語・要素除去
-
C言語 配列の長さの上限
マンスリーランキングこのカテゴリの人気マンスリー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 リストビューの行...
おすすめ情報
昇順に並び替える関数がわからないです^^;