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

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

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

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

Q&A

解決済

1回答

574閲覧

Golang クイックソートでの並び順について

prr4e

総合スコア73

Go

Go(golang)は、Googleで開発されたオープンソースのプログラミング言語です。

0グッド

2クリップ

投稿2023/01/26 11:40

編集2023/01/28 15:23

前提

Golangのクイックソートとエクセルでのソートの違いをご教授ください。

実現したいこと

以下極端な例ですが

No | 担当 | 担当No| 1 |太郎 |2 | 2 |花子 |2 | 3 |花子 |4 | 4 |三郎 |3 |

上記を踏まえてgoのクイックソートについては
2 => 2 => 3 => 4 になる可能性もあるかと思いますが、
担当名については、プログラムが
どう解釈するかは分からないため、どちらが先に来るかわがわららないということを

システムを全く知らない人にどう説明したら理解してくれるのか分からず質問させていただきました。

クイックソートは、同値の場合他の並び順は法則性がないため、
どうなるか分からないのは知っているのですが、人に説明する材料として分かり易い回答例などはありますでしょうか。

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

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

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

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

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

maisumakun

2023/01/26 12:04 編集

> 上記を踏まえてgoのクイックソートについては 2 => 3 => 1 => 4 になる可能性もあるかと思いますが、 どうしてあるのですか?担当Noが一意である以上、ソート結果も一意に定まります(ソート基準に対して順序が正しくないものは、もはやソートではありません)。
Zuishin

2023/01/26 12:08

何度読み直しても質問の主張がわかりません。もし他の人に説明したのに理解を得られずここで質問したのであれば、まずその人ではなく自分が間違っている可能性を受容する覚悟をするのが良いでしょう。 なお、標準のソートで使われているのはクイックソートではなく、複数のアルゴリズムを組み合わせたもののようです。 この質問でいう「クイックソート」がもし自作のものであるなら、その実装方法もしくは使い方が間違っている可能性もあります。
melian

2023/01/26 12:15

golang の場合、ソート対象のスライスもしくは配列の要素数によってソートアルゴリズムを変更します。 6 個以下 => insertion sort 7 〜 12個 => shell sort 基本は quick sort ですが、再帰の深さがある閾値以上になる場合は heap sort が使われます。
prr4e

2023/01/28 15:20

皆様ご回答ありがとうございました。 私も質問内容を読み返して、記述内容に誤りがあることに気づきました。 訂正いたしました。
Zuishin

2023/01/28 19:24

> システムを全く知らない人にどう説明したら理解してくれるのか分からず あなたではなくわかっている人が説明するのが良いと思います。 クイックソートのアルゴリズムを説明したサイトは数多くあるので、それを直接見てもらうのも良いでしょう。 わからない人が聞きかじったことを説明してもわかりません。 要素数が四つの場合、挿入ソートになるので順番は保証されます。
episteme

2023/01/29 01:57

> どちらが先に来るかわがわららないということを > システムを全く知らない人にどう説明したら理解してくれるのか 「非安定なソートを行うので、同値要素の並びは不定です」じゃダメ? # "非安定なソート" を説明せにゃならんのか?
prr4e

2023/01/29 08:56

ありがとうございます。 「プログラムがどう解釈するかは分からないため、どちらが先に来るかわがわららないということ」 この件をクライアントに説明してなんとか分かってもらいました。 システムを知らないクライアントに説明するにはどう説明すればいいのかを悩んでましたが、 上記でわかっていただけたので、少し取り越し苦労でした。
Zuishin

2023/01/29 09:01

SliceStable という安定ソートを教えて貰っているんだから、必要なら説明しなくてもそれを使えばいいだけですね。
prr4e

2023/01/30 01:29

ありがとうございます。 色々ご丁寧なご説明ありがとうございいました。
guest

回答1

0

自己解決

この件をクライアントに説明してなんとか分かってもらいました。
システムを知らないクライアントに説明するにはどう説明すればいいのかを悩んでましたが、
上記でわかっていただけたので、少し取り越し苦労でした

投稿2023/04/11 10:54

prr4e

総合スコア73

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問