2D 配列でバイナリサーチを実行するとガベージ値が取得されるのはなぜですか pls は私を修正してください! ! (intellij のアイデアで)


2D 配列でターゲット要素を検索する

私が試したこと:

public class binaryTwoDSearch {
    public static void main(String[] args) {
        int[][] arr = {
                {10, 20, 30, 40},
                {15, 25, 35, 45},
                {28, 29, 37, 49},
                {33, 34, 38, 50},
        };
        System.out.println(searchTwoDArray(arr,37));
    }
    static int[] searchTwoDArray(int[][] matrix , int target){
        int row = 0;
        int col = matrix.length - 1;

        while (row < matrix.length && col >= 0){
            if(matrix [row][col] == target){
                return new int[]{row,col};
            }
            if(matrix [row][col] < target){
                row ++;
            }else { // matrix [row][col] > target
                col --;
            }
        }
        return new int[]{-1,-1};
    }
}

解決策 1

コンパイルしても、コードが正しいとは限りません! :笑う:
開発プロセスは電子メールを書くことと考えてください。コンパイルが成功したということは、電子メールを適切な言語 (たとえば、ドイツ語ではなく英語) で作成したことを意味します。電子メールに送信したいメッセージが含まれていたわけではありません。

これで、開発の第 2 段階に入ります (実際には第 4 段階または第 5 段階ですが、後で前の段階に進みます): テストとデバッグです。

それが何をするのか、そしてそれがあなたが望んでいたものとどのように違うのかを見ることから始めてください。 これは、なぜそれを行っているのかについての情報を提供するため、重要です。 たとえば、プログラムがユーザーに数字を入力させることを目的としており、それを2倍にして答えを出力する場合、入力/出力が次のようになると:

Input   Expected output    Actual output
  1            2                 1
  2            4                 4
  3            6                 9
  4            8                16

次に、問題がそれを2倍にするビットにあることは明らかです-それ自体を加算したり、2倍したりするのではなく、それ自体を乗算して入力の2乗を返します。
それで、コードを見ることができ、それがここのどこかにあることは明らかです:

ジャワ
int Double(int value)
   {
   return value * value;
   }

何がうまくいかないのかがわかったら、デバッガーを使用して原因を突き止めます。 メソッドの最初の行にブレークポイントを置き、アプリを実行します。 ブレークポイントに到達すると、デバッガーが停止し、制御がユーザーに渡されます。 コードを行ごとに実行し (「シングル ステップ」と呼ばれます)、必要に応じて変数の内容を確認 (または変更) できるようになりました (コードを変更して、必要に応じて再試行することもできます)。
コードを実行する前に、コードの各行が何をすべきかを考え、「ステップ オーバー」ボタンを使用して各行を順番に実行したときに実際に何をしたかを比較します。 それはあなたが期待したことをしましたか? その場合は、次の行に進みます。
そうでない場合、なぜですか? どう違うの?
うまくいけば、そのコードのどの部分に問題があり、何が問題なのかを突き止めるのに役立つはずです。
これはスキルであり、開発だけでなく現実の世界でも役立つため、開発する価値のあるスキルです。 そして、すべてのスキルと同様に、それは使用することによってのみ向上します!

解決策 2

問題はあなたにあります println 声明。 戻り値は値の配列であり、Java には配列を出力するデフォルトのメソッドがないため、実際のコードを提供する必要があります。 だからあなたを変えてください println への声明

ジャワ
int res[] = searchTwoDArray(arr,37);
System.out.println(res[0] + " " + res[1]);



Source link

コメント

タイトルとURLをコピーしました