将输出更改为 4x4 矩阵

Changing output into 4x4 matrices

所以我正在研究 Java 中的一种方法,它基本上采用随机字符串然后通过该方法并将字符串更改为奇偶校验位,这基本上是将每个字符转换为其数值二进制格式。

这是我的:

public class ShiftData {
    //this is the method that where Logic is implemented..
    static String shiftRows(String text) {
        //character array to store given String elements into an array..
        char[] chs = text.toCharArray();
        StringBuffer samBuffer = new StringBuffer();
        //loop through the length of the character array..
        for (int i = 0; i < chs.length; i++) {
            //adding characters to the StringBuffer...
            samBuffer.append(Integer.toHexString((int) chs[i]));
//            here in the above statement toHexString method pads parity bit and converts to hexadecimal value..
        }
        return samBuffer.toString();//returning the value
    }
}

这是将字符串转换为 4x4 矩阵的代码:

if(text !=null && !text.isEmpty()) {
    int len = text.length();
    int rem = len %16;
    int padChars = 16-rem;


    for(int i =0; i < (len+padChars); i++) {
        if(i < len) {
            System.out.print(text.charAt(i)+ "   ");
        } else {
            System.out.print( "A   ");
        }

        if((i+1) % 4 == 0)
            System.out.println();
        if((i+1) % 16 == 0)
            System.out.println("\n");

     }
 }

所以基本上如果输入字符串是:WVOGJTXQHUHXICWYYMGHTRKQHQPWKYVGLPYSPWGOINTOFOPMO

输出应如下所示:

d7 56 cf 47

d4 d8 d1 ca

48 d8 48 55

59 c9 c3 d7


59 4d 47 48

d2 4b d1 d4

50 d7 48 d1

47 4b 59 56

cc 50 59 53

d7 47 cf 50

d4 cf c9 4e

4d c6 cf 50


cf 41 41 41

41 41 41 41

41 41 41 41

41 41 41 41

我只需要帮助组合代码!我可以让它们分开工作,但我无法获得我需要的输出。请说明您将如何编码。

不要使用 StringBuffer。请改用 StringBuilder

您的打印循环一次写入 一个 字母,由 3 个空格(和换行符)分隔。十六进制的字母由 两个 十六进制数字组成,正如您已经在所需的输出中显示的那样,因此它不起作用。

您的代码在末尾打印空行,这可能是您不想要的。

如果值为 0-15,

Integer.toHexString() 将 return 一个数字。

static String shiftRows(String text) {
    char[] chs = text.toCharArray();
    StringBuilder samBuffer = new StringBuilder();
    for (int i = 0; i < chs.length; i++)
        samBuffer.append(String.format("%02x", (int)chs[i])); // always 2 hex digits, even for 0-15
    return samBuffer.toString();
}

public static void main(String[] args) {
    String text = shiftRows("WVOGJTXQHUHXICWYYMGHTRKQHQPWKYVGLPYSPWGOINTOFOPMO");
    if (text != null && ! text.isEmpty()) {
        int len = (text.length() + 31) / 32 * 32; // round up to next increment of 32 (16 hex pairs)
        for (int i = 0; i < len; i += 2) {
            if (i != 0 && i % 8 == 0) { // every 4 hex pairs, but not first time
                System.out.println();
                if (i % 32 == 0) // every 16 hex pairs
                    System.out.println();
            }
            if (i < text.length())
                System.out.print(text.substring(i, i + 2) + " ");
            else
                System.out.print("41 ");
        }
    }
}