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

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

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

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

Q&A

解決済

2回答

701閲覧

配列をディープコピーをして配列を昇順に並び替えたい

janetto

総合スコア7

Java

Javaは、1995年にサン・マイクロシステムズが開発したプログラミング言語です。表記法はC言語に似ていますが、既存のプログラミング言語の短所を踏まえていちから設計されており、最初からオブジェクト指向性を備えてデザインされています。セキュリティ面が強力であることや、ネットワーク環境での利用に向いていることが特徴です。Javaで作られたソフトウェアは基本的にいかなるプラットフォームでも作動します。

0グッド

0クリップ

投稿2022/05/13 08:10

編集2022/05/13 08:11

出したい実行結果

並び替え前:{ 80 30 60 10 40 70 50 20 } 並び替え後:{ 10 20 30 40 50 60 70 80 }

現状のコード

Java

1public int sort(int[] num){ 2 int [] sortedNum =new int [num.length] ; 3 4 for (int i = 0; i<sortedNum.length;i++){ 5 int min =0; 6 int minIdx = i; 7 8 for(int j = j+1; j<sortedNum.length; j++) { 9 if(sortedNum[j]<min[minIdx]){ 10 minIdx=j; 11 } 12 } 13 14 int temp = sortedNum[i]; 15 sortedNum[i] = sortedNum[minIdx]; 16 sortedNum[minIdx]=temp; 17 18 } 19 20 return sort; 21 }

Java

1public class Main { 2 3 public static void main(String[] args) { 4 int[] num = {80, 30, 60, 10, 40, 70, 50, 20}; 5 MyArrays arrays = new MyArrays(); 6 int[] sortedNum = arrays.sort(num); 7 8 System.out.print("before:{ "); 9 for (int i = 0; i < num.length; i++) { 10 System.out.print(num[i] + " "); 11 } 12 System.out.println("}"); 13 14 System.out.print("after:{ "); 15 for (int i = 0; i < sortedNum.length; i++) { 16 System.out.print(sortedNum[i] + " "); 17 } 18 System.out.println("}"); 19 } 20}

現状のコンパイル結果

Toi18Main.java:6: エラー: 不適合な型: intをint[]に変換できません:
int[] sortedNum = arrays.sort(num);
^
.\MyArrays.java:50: エラー: 配列が要求されましたが、intが見つかりました
if(sortedNum[j]<min[minIdx]){
^
.\MyArrays.java:61: エラー: シンボルを見つけられません
return sort;
^
シンボル: 変数 sort
場所: クラス MyArrays
エラー3個

条件

  • Mainクラスは変えない
  • パッケージ、インポートは使わない

わかっていること

ディープコピーをすること

やってみたこと

https://www.delftstack.com/ja/howto/java/java-deep-copy-array/
https://www.sejuku.net/blog/14067
https://www.javadrive.jp/start/array/index2.html

添付サイトを参考にしたコードの修正

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

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

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

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

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

xebme

2022/05/13 19:31 編集

int[]はプリミティヴ型の配列なのでディープコピーする必要はありません。ディープコピーをどのように理解しているのか説明してください。 ↑これは私が間違いました。配列本体は参照がコピーされるのでシャローコピーになります。要素もコピーするのがディープコピーでした。 要素が参照型の配列は、要素自体のディープコピーが必要。こちらのことを考えていました。
janetto

2022/05/15 23:14

解決しましたありがとうございました。
guest

回答2

0

ベストアンサー

java

1public class MyArrays { 2 public int[] sort(int[] num){ 3 int [] sortedNum =new int [num.length] ; 4 5 for (int i = 0; i < num.length;i++){ 6 int minIdx = 0; 7 for (int j = i - 1; j >= 0; j--) { 8 if (sortedNum[j] < num[i]) { 9 minIdx = j+1; 10 break; 11 } 12 sortedNum[j+1] = sortedNum[j]; 13 } 14 sortedNum[minIdx] = num[i]; 15 } 16 17 return sortedNum; 18 } 19} 20

投稿2022/05/13 08:50

h-okhs

総合スコア149

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

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

janetto

2022/05/15 23:14

解決しましたありがとうございました。
guest

0

Toi18Main.java:6: エラー: 不適合な型: intをint[]に変換できません:
int[] sortedNum = arrays.sort(num);
^

->int[] じゃなく、int 返してます。↓

public int sort(int[] num){

---

.\MyArrays.java:50: エラー: 配列が要求されましたが、intが見つかりました
if(sortedNum[j]<min[minIdx]){
^

-> minは配列じゃないですよ。↓ホラ。

int min =0;

---

.\MyArrays.java:61: エラー: シンボルを見つけられません
return sort;
^
シンボル: 変数 sort

-> sortって変数じゃなくてメソッド名じゃないですか?

エラーの箇所やエラー内容、よく見ると原因書いてあります。
変数名はわかりやすく、他と混同しないような名前にしたほうがバグ少なくなるかと思いますよ。

投稿2022/05/13 08:23

編集2022/05/13 08:29
kaputaros

総合スコア1844

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

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

janetto

2022/05/15 23:14

解決しましたありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問