【算法题】 TLV解析 Ⅱ (js)

发布时间:2023年12月18日

在这里插入图片描述
在这里插入图片描述
从第三个字节开始因此

const msg = "0F04ABABABAB";
const msg1 = "0F04ABABABAB10001FF";
function solution(msg, tags) {
  const tagObj = {};
  for (let i = 0; i + 3 < msg.length; ) {
    const tag = parseInt(msg.slice(i, i + 2), 16);
    const len = parseInt(msg.slice(i + 2, i + 4), 16);
    const valueOffset = Math.floor((i + 5) / 2);
    console.log(tag);
    console.log(len);
    console.log(valueOffset);

    i = i + 3 + len * 2;
    // 如果结束位置越界则报文不完整,需要舍弃
    if (i >= msg.length) break;
    tagObj[tag] = [len, valueOffset];
  }

  const res = tags.map((tag) => {
    if (tagObj[tag]) {
      const [len, valueOffset] = tagObj[tag];
      return `${len} ${valueOffset}`;
    } else {
      return `0 0`;
    }
  });
  return res.join("\n");
}

console.log(solution(msg, [15]));
/* 
0F04ABABABAB
1
15
=>
4 2

0F04ABABABAB10001FF
2
15
17
=>
4 2
0 0
 */

文章来源:https://blog.csdn.net/qq_43682422/article/details/135057354
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。