繁体   English   中英

将输出更改为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()将返回一位数字。

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 ");
        }
    }
}

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM