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

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

ただいまの
回答率

90.50%

  • Java

    13793questions

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

  • 配列

    522questions

    配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

  • for

    226questions

    for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

  • if

    203questions

    if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

2つの配列を用いて配列の中身が共通の数とどちらかに入っている数を表示させたいです。

解決済

回答 4

投稿

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

ssssa

score 27

Java初心者です。

<前提・実現したいこと>
----Prob8-11----
長さ10の整数型の配列変数を2つ用意し、それぞれに、各要素に1から10の整数を代入し、以下のようにそれぞれの配列に共通する値の一覧のみが入った配列と、2つのうちどちらかに入る数値の一覧を小さい準に代入した配列を作りなさい。
----回答例----
配列1:  4  9  4  3  6  8  7  1  3  10
配列2:  7  3  10  7  5  9  4  9  9  1
共通の数:1  3  4  7  9  10
どちらか入っている数:1  3  4  5  6  7  8  9  10

下記コード詳細です。
public class Prob8_11 {

/**

  • @param args
    */
    public static void main(String[] args) {
    int hairetu1[] = new int[10];
    int hairetu2[] = new int[10];
    int kyoutu[] = new int[10];
    int dotiraka[] = new int[10];

System.out.print("配列1:");
for (int i = 0; i < 10; i++) {
hairetu1[i] = (int) (Math.random() * 10) + 1;
System.out.print(hairetu1[i] + " ");
}

System.out.println(" ");
System.out.print("配列2:");
for (int i = 0; i < 10; i++) {
hairetu2[i] = (int) (Math.random() * 10) + 1;
System.out.print(hairetu2[i] + " ");
}
System.out.println("");
System.out.println("共通の数:");
for (int i = 0; i < 10; i++) {
if (hairetu1[i] == hairetu2[i]) {
kyoutu[i] = hairetu1[i] = hairetu2[i];
System.out.print(kyoutu[i] + " ");
}
}
System.out.println("");
System.out.println("どちらかの数:");
for (int i = 0; i < 10; i++) {
if (hairetu1[i] >= hairetu2[i]) {
dotiraka[i] = hairetu1[i];
System.out.print(dotiraka[i] + " ");

}

}
}
}

if文の条件がわからず、期待値通りの答えが出ません。
どなたかご教示していだけませんでしょうか?
 

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

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

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

    クリップを取り消します

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

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

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

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

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

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

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

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

    質問の評価を下げる

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

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

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

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

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

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

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

    詳細な説明はこちら

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

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

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

質問への追記・修正、ベストアンサー選択の依頼

  • euledge

    2018/07/16 18:30

    1から10までの数字と決まっているので、入っている数字と配列のインデックスを関連させてみるとboolean配列を使うという意味がわかると思いますよ

    キャンセル

  • unz.hori

    2018/07/18 16:03

    結果を格納するのにArrayListを使って良いのならboolean配列は必要ない気もするけど制限あるのかな?

    キャンセル

  • unz.hori

    2018/07/18 16:26

    同一の値が複数回出現するのかしないのかによっても結構難易度が変わってくるなぁ

    キャンセル

回答 4

checkベストアンサー

+1

えーと、積集合(intersection)と和集合(union)をつくればいいのね。

import java.util.Arrays;
import java.util.HashSet;

public class set_operations {

  static void intersection(int[] set1, int[] set2) {
    HashSet<Integer> uniq = new HashSet<Integer>();
    int inx1 = 0;
    int inx2 = 0;
    while ( inx1 < set1.length && inx2 < set2.length ) {
      int val1 = set1[inx1];
      int val2 = set2[inx2];
      if ( val1 < val2 ) {
        ++inx1;
      } else if ( val1 > val2 ) {
        ++inx2;
      } else {
        if ( uniq.add(val1) ) { System.out.printf("%d ", val1); }
        ++inx1;
        ++inx2;
      }
    }
  }

  static void union(int[] set1, int[] set2) {
    HashSet<Integer> uniq = new HashSet<Integer>();
    int inx1 = 0;
    int inx2 = 0;
    while ( inx1 < set1.length && inx2 < set2.length ) {
      int val1 = set1[inx1];
      int val2 = set2[inx2];
      if ( val1 < val2 ) {
        if ( uniq.add(val1) ) { System.out.printf("%d ", val1); }
        ++inx1;
      } else if ( val1 > val2 ) {
        if ( uniq.add(val2) ) { System.out.printf("%d ", val2); }
        ++inx2;
      } else {
        if ( uniq.add(val1) ) { System.out.printf("%d ", val1); }
        ++inx1;
        ++inx2;
      }
    }
    while ( inx1 < set1.length ) {
      int val1 = set1[inx1];
      if ( uniq.add(val1) ) { System.out.printf("%d ", val1); }
      ++inx1;
    }
    while ( inx2 < set2.length ) {
      int val2 = set2[inx2];
      if ( uniq.add(val2) ) { System.out.printf("%d ", val2); }
      ++inx2;
    }
  }


  public static void main(String[] arg) {
    int set1[] = new int[] { 4,  9,  4,  3,  6,  8,  7,  1,  3,  10 };
    int set2[] = new int[] { 7,  3,  10,  7,  5,  9,  4,  9,  9,  1 };

    Arrays.sort(set1);
    Arrays.sort(set2);

    System.out.print("\nintersection: "); intersection(set1, set2);
    System.out.print("\nunion:        "); union(set1, set2);

  }
}

/* 実行結果
intersection: 1 3 4 7 9 10
union:        1 3 4 5 6 7 8 9 10
*/

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/08/05 23:04

    本当にありがとうございます。お返事が遅れまして大変申し訳ございません。
    参考にさせていただきます。

    キャンセル

+1

あまり良い考え方ではなかったのでやり直し。
共通を表す条件どちらかを表す条件を考えて下さい。

ヒント:

true && true  = true
true && false = false

true || true  = true
true || false = true
boolean flags1[] = new boolean[10]; //配列1用フラグ
boolean flags2[] = new boolean[10]; //配列2用フラグ

//それぞれのフラグを立てる
for (int i = 0; i < 10; i++) {
    flags1[hairetu1[i]-1] = true;
    flags2[hairetu2[i]-1] = true;
}

:

System.out.println("共通の数:");
for (int i = 0; i < 10; i++) {
    if (共通を表す条件) {
        System.out.print(i+1 + " ");
    }
}

:

System.out.println("どちらかの数:");
for (int i = 0; i < 10; i++) {
    if (どちらかを表す条件) {
        System.out.print(i+1 + " ");
    }
}

 ダメ回答

「どちらか」だけ丸投げ回答。
「共通」は自分で考えてね。

ヒント:

true && true  = true
true && false = false
//どちらかに入っているフラグ
boolean flagsOr[] = new boolean[10];

//orなので気にせず上書き
for (int i = 0; i < 10; i++) {
    flagsOr[hairetu1[i]-1] = true;
    flagsOr[hairetu2[i]-1] = true;
}

System.out.println("どちらかの数:");
for (int i = 0; i < 10; i++) {
    if (flagsOr[i]) {
        System.out.print(i+1 + " ");
    }
}
配列1:10 9 2 8 10 9 8 7 10 5  
配列2:3 3 7 3 10 4 3 7 10 7 

どちらかの数:
2 3 4 5 7 8 9 10 

投稿

編集

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/07/23 22:01

    ありがとうございます。参考にさせていただきます。

    キャンセル

+1

両方に存在する数:(bpthExist) - 2つのListを順次繰り返して、合致したものだけをいれる。

片方には存在する数(両方いてもいい) - 2つのListを合成させたときに、自動的に重複が削除される java.util.Setの実装クラスを使うか、streamのdistinctを使って重複を削除する。

  1. 両方に存在するもの
    public List<Integer> bothExist(List<Integer> first, List<Integer> second) {
        return first.stream().map(f -> exists(f, second)).filter(f -> f.isPresent()).map(f -> f.get()).sorted().collect(Collectors.toList());
    }

    static Optional<Integer> exists(Integer select, List<Integer> targets) {
        return targets.stream().filter(target -> target.intValue() == select.intValue()).findFirst();
    }
  1. 片方に存在していればよいもの
public List<Integer> leastExist(List<Integer> first, List<Integer> second) {

    first.addAll(second);

    return first.stream().distinct().sorted().collect(Collectors.toList());
}

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/07/30 09:52

    1. 前者のコードで、existsメソッドの返り値をbooleanにして最初からfilterを使えば早いのでは
    2. 後者はListを書き換えているので、Stream#concatのほうがベターな気がします

    キャンセル

0

考え方のみ

どちらかに入っている
→HashSet

どちらにも入っている
→HashSet+remove(notIn)

どちらかのみ入っている
→HashSet+remove(どちらにも入っている)

投稿

  • 回答の評価を上げる

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

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

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

  • 回答の評価を下げる

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

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

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

  • 2018/08/05 23:05

    お返事が遅れまして大変申し訳ございません。
    考え方ありがとうございます。
    参考にさせていただきます。

    キャンセル

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

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

関連した質問

  • 解決済

    java 乱数 配列

            }     } なるべく短いプログラムにしたいです。よろしくお願いします。

  • 解決済

    メソッドの切り離しについて (Java学習中)

    こんばんは。 今日は、メソッドについての質問です。 とても簡単なプログラミングで、数値を入力してもらってそれを左から順番に小さい方から並べるというものを作ろうとしました。 こ

  • 解決済

    javaのカウントアップについて

    javaのEclipseを使っています。 カウントアップ後、表示する度に、 1, 2, 3, …と表示するプログラムを作りたいです。 プログラム例を教えて下さい。 2つのインス

  • 受付中

    ループ化の方法

    public class Gohkaku {     public static void main(String[] args){         int math = ne

  • 受付中

    java For文が正常に動きません。

    初心者なのですが、forが処理できません。なぜでしょうか? 教えてくださいよろしくお願いします。 package game; import java.util.Rando

  • 解決済

    乱数表示から最大値を表示する Java

    いつもお世話になっております。 現在変数を表示させてから、最大値を求めるプログラムを組んでいます。 乱数は表示できる状態です。 開発環境Eclipse、言語はJavaです

  • 解決済

    javaで作れる学習プログラムってどのようなものが作れますか

    意図 javaを使って学習プログラムを作成してほしいといわれました。 しかし、イメージがわきません。 どんなものが作れるのでしょうか

  • 解決済

    改行区切りでの出力

    ランダムな整数を改行区切りで3個出力したくて以下のコードを打ってみたんですが間違いといわれました。どこが違うのか指摘お願いします  public class Main {  p

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

  • Java

    13793questions

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

  • 配列

    522questions

    配列は、各データの要素(値または変数)が連続的に並べられたデータ構造です。各配列は添え字(INDEX)で識別されています。

  • for

    226questions

    for文は、様々なプログラミング言語で使われている制御構造です。for文に定義している条件から外れるまで、for文内の命令文を繰り返し実行します。

  • if

    203questions

    if文とは様々なプログラミング言語で使用される制御構文の一種であり、条件によって処理の流れを制御します。

  • トップ
  • Javaに関する質問
  • 2つの配列を用いて配列の中身が共通の数とどちらかに入っている数を表示させたいです。