题目描述:
TLV 编码是按 [ Tag Length Value ] 格式进行编码的,一段码流中的信元用Tag标识, Tag在码流中 唯一不重复 ,Length表示信元Value的长度,Value表示信元的值。
码流以某信元的Tag开头,Tag固定占 一个字节,Length固定占 两个字节,字节序为 小端序 。
现给定TLV格式编码的码流,以及需要解码的信元Tag,请输出该信元的Value。
输入码流的16进制字符中,不包括小写字母,且要求输出的16进制字符串中也不要包含小写字母;
码流字符串的最大长度不超过50000个字节。
输入描述:
输入的第一行为一个字符串,表示待解码信元的 Tag ;
输入的第二行为一个字符串,表示待解码的 16进制码流 ,字节之间用 空格分隔 。
输出描述:
输出一个字符串,表示待解码信元以16进制表示的 Value 。
示例 1 :
输入
31
32 01 00 AE 90 02 00 01 02 30 03 00 AB 32 31 31 02 00 32 33 33 01 00 CC
输出
32 33
说明
需要解析的信元的Tag是31,从码流的起始处开始匹配,
Tag为32的信元长度为1(01 00,小端序表示为1);
第二个信元的Tag是90,其长度为2;
第三个信元的Tag是30,其长度为3;
第四个信元的Tag是31,其长度为2(02 00),所以返回长度后面的两个字节即可,即32 33。
java代码
package odTest;
import java.util.Arrays;
import java.util.Scanner;
public class TLVcode {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
String aimSign = scanner.nextLine();
String[] inputs = scanner.nextLine().split(" ");
String aimValueIndex = "";
for(int i=0;i<inputs.length;) {
if(aimSign.equals(inputs[i])) {
int lenght = Integer.parseInt(inputs[i+1]);
i=i+3;
lenght = i+lenght;
aimValueIndex =i+"-"+ lenght;
break;
}else {
int lenght = Integer.parseInt(inputs[i+1]);
i = i+3+lenght;
}
}
int[] aimValueList = Arrays.stream(aimValueIndex.split("-")).mapToInt(Integer::parseInt).toArray();
for(int i=aimValueList[0];i<aimValueList[1];i++) {
System.out.print(inputs[i]+" ");
}
}
}