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

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

ただいまの
回答率

87.78%

Javaでの配列の代入

解決済

回答 2

投稿

  • 評価
  • クリップ 0
  • VIEW 1,010

score 139

前提・実現したいこと

どうもこんにちは。初めてこのサイトを利用させていただきます。

最初に書きますが、バグの質問ではないです。
配列のコピーについて質問させていただきます。

今、コンストラクタでは、newでメモリ確保したあと、for文を回して1つ1つ値を代入しています。正直面倒です。もっとスマートな方法はないのでしょうか?
プログラミング自体、まだ経験が浅いので、どんどん知識を蓄えたいです。よろしくお願いします。

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

なし

該当のソースコード

public class RubixCube{

    public static final int BACK = 0;
    public static final int UP = 1;
    public static final int LEFT = 2;
    public static final int FRONT = 3;
    public static final int RIGHT = 4;
    public static final int DOWN = 5;

    public static final char[][][] finished_state = {// 揃った状態
        {{'O','O','O'},{'O','O','O'},{'O','O','O'}},// BACK
        {{'Y','Y','Y'},{'Y','Y','Y'},{'Y','Y','Y'}},// UP
        {{'B','B','B'},{'B','B','B'},{'B','B','B'}},// LEFT
        {{'R','R','R'},{'R','R','R'},{'R','R','R'}},// FRONT
        {{'G','G','G'},{'G','G','G'},{'G','G','G'}},// RIGHT
        {{'W','W','W'},{'W','W','W'},{'W','W','W'}},// DOWN
    };

// キューブの状態保存用
    private char[][][] state;

    RubixCube(){// 揃った状態を代入
        state = new char[6][3][3];
        for(int surface=0 ; surface<6 ; surface++){
            for(int j=0;j<3;j++){
                for(int i=0;i<3;i++){
                    this.state[surface][j][i] = finished_state[surface][j][i];
                }
            }
        }
    }
//以下省略

試したこと

this.state = finished_state;
としたがfinished_stateが書き代わってしまってうまくいかなかった。

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

より詳細な情報

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

回答 2

checkベストアンサー

+1

Java言語に限らずコピーには浅いコピー(shallow copy)と深いコピー(deep copy)という概念がありますが本件は(javaの多次元配列はC/C++/C#などでジャグ配列と呼ばれるもので「配列オブジェクトの入れ子」構造で実現されているため)deep copy問題にあたります。

ちなみに浅いコピー・深いコピーの一般問題はObject#cloneのリファレンスを読み、色々実験してみるとよいと思います。


訂正:最初の回答にArrays#copyOfでdeep copyができると書きましたがそれは間違いでshallow copyでした。大変失礼しました。
forループのネストは確かに今一つな感じですが汎用的なコピーメソッドはないようで、それを書こうとするとややこしくなりそうなので次元数が固定ならforループが一番素朴で分かりやすいかも知れません。最後の次元だけは若干簡単にかけます。

state = new char[6][3][];
for (int surface = 0 ; surface < 6 ; surface++){
  for (int j = 0; j < 3; j++){
    state[surface][j] = Arrays.copyOf(finished_state[surface][j], 3);
  }
}

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/12/11 19:29

    こんばんわ。どうもご回答ありがとうございました。今回は具体的なコードを示してくださったKSwordOfHaste様をベストアンサーにさせていただきます。shallow copyとdeep copyですか…。勉強になりました。勝手ながらフォローさせていただきます。

    キャンセル

0

6‐13. 配列7 配列の複製
6-14. 配列8 配列の複製2

多次元配列では特に下のリンクが参考になります。
結論から言うと、普通に複製してしまってはどうしても参照のみのシャローコピーになってしまうので、面倒な方法をとらざるを得ないといったところですね…。

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2016/12/11 19:29

    こんばんわ。どうもご回答ありがとうございました。ベストアンサーにはほかの方を選ばさせていただきましたが、swordone様の回答も大変参考になりました。普通に複製しては今回の場合ダメなんですね。勉強になりました。リンクまで貼っていただき、ありがとうございました。

    キャンセル

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

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

関連した質問

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