
No.2ベストアンサー
- 回答日時:
例えばバブルソートは
for j=0 to AMax
for i=1 to AMax-j
if A(i-1)>A(i) then
入れ替え
end if
next
next
大体こんな感じですよね。
ここでは、大小比較に「>」を使っています。
ここで 「比較」 という関数を定義したとします。
比較(x,y) :
x が yより「大きい」ときは 正の値、「等しい」なら0、 「小さい」なら負の値を返す
これを使うと
for j=0 to AMax
for i=1 to AMax-j
if 比較(A(i-1),A(i)) > 0 then
入れ替え
end if
next
next
と書けます。
さて
「大きい」「等しい」「小さい」
と「」付きで書いたのには理由があります。
後ろにくるべきものを「大きい」前にくるべきものを「小さい」と判定するように作れば、実は、実際の数値の大小以外にも使えるのです。
例えば 、x>y のとき 負、x<yのとき正 として作れば 実際には数の小さい方が「大きい」というということになり、その結果、逆順にソートされます。
この比較関数を使った方法は、他のアルゴリズムでも同様です。
> 文字列を五十音順にソートしたい場合
五十音順並べた時の大小関係を返す比較関数を用意しましょう。
いわゆる「辞書順」というのは
(1) 1文字目同士比較する。
(2) 違いがあれば、(1)の比較結果が文字列同士の比較結果
(2-1) もし、どちらか一方だけが文字が無い場合は、短い方が「小さい」
(2-2) 両方との文字が無くなったら、「等しい」
(3) 2文字目、3文字目...について(1)から同様に確認
というアルゴリズムになっています。
一応、文字列も 不等号で比較できますし、 StrCompという文字列比較関数もあります。
これらで間に合うようなら、使えばいいでしょう。
それで期待通りにならない場合は、比較関数を自作してみましょう。
No.3
- 回答日時:
「五十音順にソート」というのが漢字交じりの文字列なら、簡単にはいきません。
たとえば単純なコード比較だと「恵子」(けいこ)は「恵」(めぐみ)の後ろになってしまいます。
一般的には、漢字→かな(ローマ字)変換プログラムの「KAKASI 」を使うと思いますが、同システムをクライアントかサーバかにインストールしなければなりません。
http://kakasi.namazu.org/index.html.ja
Windowsでの使用例は
http://hp.vector.co.jp/authors/VA041117/ja7uhv/K …
あたり
No.1
- 回答日時:
アルゴリズムはわかると言うことであれば、別にどの方法をとってもいいと思います。
データ数が少ないと思いますので、速度を求める必要は無く、一番簡単な方法で良いかと。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
似たような質問が見つかりました
- Excel(エクセル) 結合セルのソートについて 5 2022/04/22 11:57
- その他(プログラミング・Web制作) sortの優先キーについて(スプレッドシート) 1 2023/01/17 17:59
- C言語・C++・C# メインプログラムに#include <algorithm>を書いて、 そのメインプログラムが // 3 2023/05/02 11:24
- Excel(エクセル) Excel 効率的な名簿と得点の管理の仕方 8 2022/08/07 08:15
- Excel(エクセル) Excelの50音順ソートを全ての行列に適用するには? 4 2022/12/05 11:28
- Excel(エクセル) エクセルのソート方法について 1 2023/01/13 00:01
- Excel(エクセル) excel 行でソートすると計算式が上手くいかない。 6 2022/06/01 08:18
- Excel(エクセル) 重複しているか否かをソートせずに判断する方法ありますか? 2 2022/07/06 21:16
- C言語・C++・C# C言語プログラム変更 2 2022/12/21 15:03
- Excel(エクセル) Excelでの検索結果を含む行だけを表示させたい 5 2023/03/10 17:08
このQ&Aを見た人はこんなQ&Aも見ています
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
System.IO.Directory.GetFiles...
-
C# DataTableの行をソートしてD...
-
C# DataGridView のヘッダーセ...
-
あるディレクトリ内のファイル...
-
数字文字列のソート方法
-
VB.NETでファイル名順にファイ...
-
C言語について
-
DataGridViewの複数列を連動し...
-
datatablesのソートを数字順に...
-
VBA基本構文の作り方 2列の...
-
DataGridViewの昇順降順。
-
クイックソートしながら重複要...
-
qsortについて
-
vbでDataTableの抽出コピー
-
2次元配列を複数項目でソートし...
-
GridViewで列のソートを無効に...
-
excel VBA の条件をつけての列...
-
(VBA) Dir 関数で取得するファ...
-
DataGridViewソート時に先頭行...
-
多次元配列のソート方法
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
System.IO.Directory.GetFiles...
-
VB.NETでファイル名順にファイ...
-
C# DataGridView のヘッダーセ...
-
VBA基本構文の作り方 2列の...
-
C# DataTableの行をソートしてD...
-
DataGridViewの複数列を連動し...
-
C言語・要素除去
-
ファイル名「1.jpg ~10.jpg~...
-
あるディレクトリ内のファイル...
-
Excelですべての組合せ(重複組...
-
DataGridViewの昇順降順。
-
n番目に大きい数を求めるアル...
-
C++ 入力した3つのint型の整数...
-
vbでDataTableの抽出コピー
-
2次元配列を複数項目でソートし...
-
DataGridViewソート時に先頭行...
-
文字列をソートする方法
-
(VBA) Dir 関数で取得するファ...
-
excel VBA の条件をつけての列...
-
excel VBA リストビューの行...
おすすめ情報