题目首先会给定一个tag,然后给你一个字符串,对于每一段码流,第一个字符串表示当前的tag,第二个字符串和第三个字符串的十六进制组合表示长度lenth,接下来lenth个字符串表示value,我们要找到当前的tag等于题目给定的tag时长度为lenth个value直接输出即可
模拟一遍过程即可
c++
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
signed main()
TLV编码是按[TagLengthValue]格式进行编码的,,一段码流中的信元用Tag标识,Tag在码流中唯一不重复,Length表示信元Value的长度,Value表示信元的值。
码流以某信元的Tag开头,Tag固定占一个字节,Length固定占两个字节, 字节序为小端序。
现给定TLV格式编码的码流,以及需要解码的信元Tag,请输出该信元的Value。
输入码流的16进制字符中,不包括小写字母,且要求输出的16进制字符串中也不要包含小写字母;码流字符串的最大长度不超过50000个字节。
输入的第一行为一个字符串,表示待解码信元的Tag;
输入的第二行为一个字符串,表示待解码的16进制码流,字节之间用空格分隔。
输出一个字符串,表示待解码信元以16进制表示的Value。
输入
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。