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

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

ただいまの
回答率

90.33%

  • Swift

    7666questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    4332questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

swift3で配列の順列を得たい

解決済

回答 1

投稿

  • 評価
  • クリップ 0
  • VIEW 493

meia

score 20

前提・実現したいこと

swift3
xcode8で作業しています

swiftで配列をランダムに並べ替えたくてPlaygroundで練習しています。
以下のサイトを参考に作業しております。
Swift:重複しない乱数について
順列を一瞬で取得するプログラム

2つ目のリンクの内容をswiftで表現したいのですが、うまくいかなくて困っております

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

fatal error : index out of range

該当のソースコード

// 元はJavascriptの「n個の数字の順列において、辞書式順序のm番目を戻す」コードだそうです

let n:Int = 5
var m:Int = 2

    var temp:[Any] = []
    for i in 0..<n{
        temp[i] = i
    }

    var surplus:[Any] = []

    for i in 1..<n{
     // この下の行で上記のエラーが出現します。
        surplus[n - i] = m % i
        m = Int(floor(Double(m/i)))
    }

    surplus[0] = m

    var order:[Any] = []
    for i in 0..<n{
        let num:Int = surplus[i] as! Int
        order[i] = temp[num]
        for j in num..<n - 1{
            temp[j] = temp[j + 1]
        }
    }

print(order)

試したこと

上記のほかでも、配列の順列(重複しない乱数)を取得できる方法があれば、それでも構わないので、ご存知の方がいらしたら教えていただきたいです。

補足情報(言語/FW/ツール等のバージョンなど)

そのほかにもm = Int(floor(Double(m/i)))のところやfor j in num..<n - 1のところが本来のものと違ったりして、おかしい場所があるので、ついでに教えていただけると助かります。

よろしくお願いいたします。

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

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

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

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 1

checkベストアンサー

0

このコードが何をやっているのか意味はわかりませんが、
とりあえず「index out of range」が出る原因は、

var temp:[Any] = []


と要素数が0個の配列を定義しているところに

for i in 0..<n {
    temp[i] = i
}


で要素の存在しない配列番号に代入しようとしているためだと思います。
JavaScriptは要素の存在しないところに代入したら自動的にその要素が
作られますが、Swiftは自動的には作られません。

var temp = [Int](repeating: 0, count: n)


のように、あらかじめn個の要素を持った配列を定義すれば、
とりあえず今のエラーは消えると思います。
surplusやorderの定義も同様です。

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2017/02/23 20:11

    丁寧な解説ありがとうございました!
    おかげでエラーを解決することができました!

    キャンセル

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

  • ただいまの回答率 90.33%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる

同じタグがついた質問を見る

  • Swift

    7666questions

    Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

  • Xcode

    4332questions

    Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。