0

10000 個の乱数のファイルで 1000 個のキーを順次検索し、arr が見つけたキーを出力するコードを書きました。

これが以下のコードです。実行しても何も得られません。私の間違いはどこですか?

public class SeqSample2 {

    public static void main(String[] args) {
        double[] a;
        double[] b;
        a = new double[10000];
        b = new double[1000];
        for (int i = 0; i < 1000; i++) {
            a[i] = (int) ((Math.random() * 10000));
        }
        for (int j = 0; j < 1000; j++) {
            b[j] = (int) ((Math.random() * 1000));
        }

        int lim = a.length - b.length;
        int i = 0;
        int j = 0;
        boolean found = false;
        for (i = 0; i < lim; i++) {

            if (b[0] == a[i]) {
                found = true;

                for (j = 0; j < b.length; j++) {
                    if (b[j] != a[i + j]) {
                        found = false;
                        break;
                    }
                }
                if (found) {
                    System.out.println(b[i]);
                } else {
                    System.out.println("Not found");
                }
            }
        }
    }
}
4

1 に答える 1

2

なぜあなたは驚いたのですか?

  • b[0]は 0 から 1,000 までの乱数です。
  • a[i]は 0 ~ 10,000 の乱数でi < 1,000、 は 0 ですi >= 1,000

プログラムを数回実行すると、最終的に出力が得られますが、ほとんどの場合、if (b[0] == a[i])false になり、プログラムは何も出力せずに終了します。

于 2012-07-14T12:35:55.570 に答える