0

誰かが次のエラーで私を助けてくれますか? スレッド メイン java.lang.arrayindexoutofboundsexception での例外: RowTrans.main(Rowtrans.java:7) で RowTrans.encrypt(Rowtrans.java:33) で 3

私のプログラムでは、テキストを取得したいと考えています。5 列のマトリックスに配置し、テキストの長さに応じて行を決定します。次に、列と行の位置を変更して、行が列の位置を取得し、列が行を取得するようにします。行に 5 つの値が含まれていない場合、空のスペースに文字 Z を追加します。このエラーについて誰か助けてください。

これが私のコードです

import java.util.Scanner;

public class ColTrans {

   public static void main(String[] args)
   {
      String ori = "This is my horse";
      String enc = encrypt(ori);
      System.out.println(enc);
      // String dec = decrypt(enc);
      // System.out.println(dec);
   }

   static String encrypt(String text)
   {
      String result = "";
      text = text.toUpperCase();
      int length = text.length();
      int rows = length / 5;
      char[][] b = new char[rows][5];
      char[][] c = new char[5][rows];
      char[] d = new char[length];
      if ((length % 5) != 0)
         rows = rows + 1;

      int k = 0;
      for (int i = 0; i < rows; i++)
         for (int j = 0; j < 5; j++)
         {
            if (k > length)
               b[i][j] = 'Z';
            else
            {
               d[k] = text.charAt(k);
               b[i][j] = d[k];
            }

            k++;
         }

      for (int i = 0; i < 5; i++)
         for (int j = 0; j < rows; j++)
         {
            c[i][j] = b[j][i];
            result = result + c[i][j];
         }

      return result;

   }
}
4

4 に答える 4

0

次のようにコードを変更するだけです:

if ((length % 5) != 0)
   rows = rows + 1;
char[][] b = new char[rows][5];
char[][] c = new char[5][rows];
char[] d = new char[length];
于 2013-05-16T09:20:55.000 に答える
0

あなたの説明によると:

text = text.toUpperCase();
    char[] b = text.toCharArray();
    char[][] c = new char[b.length][5];

    int bLen = 0;
    for (int i = 0; i < c.length; i++) {
        for (int j = 0; j < 5; j++) {
            if(bLen < b.length)
                c[i][j] = b[bLen++];
            else
                c[i][j] = 'Z';

        }
    }

 //change the column and row position 
 char[][]d = new char[c[0].length][c.length];

    for (int i = 0; i < d.length; i++) {
        for (int j = 0; j < d[0].length; j++) {
            d[i][j] = c[j][i];

        }
    }

出力:TI EZZZZZZZZZZZZHSHZZZZZZZZZZZZZI OZZZZZZZZZZZZZSMRZZZZZZZZZZZZZ YSZZZZZZZZZZZZZ

于 2013-05-16T09:21:09.170 に答える
0

コードには 2 つの問題があります。まず、マトリックスのインスタンス化の前に mod 部分を移動します。

  if ((length % 5) != 0)
     rows = rows + 1;

   char [][] b =new char[rows][5];
   [...]

次に、に変更if ( k > length )しますif ( k >= length )

于 2013-05-16T09:07:04.240 に答える