题解 | #MP3光标位置#

MP3光标位置

http://www.nowcoder.com/practice/eaf5b886bd6645dd9cfb5406f3753e15

后面注释的数据是出现错误的用例和结果
我编写的时候 有一个判定条件一直被忽略 
当总数据小于4条时,且光标位置不等于第一条,进行U 向上查询指令,
此时光标位置应是list列表的最后一条数据 之前我写的是固定值4,导致一条用例不通过
欢迎大家指点并讨论^-^

let line;
let inputArr = [];
while ((line = readline())) {
  inputArr.push(line);
}
let list = [1, 2, 3, 4]; // 记录当前歌曲列表
let point = 1; // 光标初始化
function main(num, str) {
   //初始化 歌曲列表数据
  let arr = new Array(Number(num)).fill(0).map((x, index) => {
    x = index + 1;
    return x;
  });

  for (let i of str) {
    if (i == "U") {
      up(arr, num);
    }
    if (i == "D") {
      down(arr, num);
    }
  }
  console.log(list.join(" "));
  console.log(point);
}

main(inputArr[0], inputArr[1]);

function up(arres, num) {
  let arr = arres.concat();
  if (arr.length <= 4) {
    list = arr;
    point = point != 1 ? point - 1 : arr[arr.length-1];
  } else { // 总数大于4
    if (point != 1) {
      point = point - 1;
      let filte = list.filter((x) => x == point);
      if (filte.length <= 0) {
          list = arr.splice(point - 1, 4);
      }
    } else {
      point = parseInt(num);
      list = arr.splice(num - 4, 4);
    }
  }
}

function down(arres, num) {
  let arr = arres.concat();
  if (arr.length <= 4) {
    list = arr;
    point = point != num ? Number(point) + 1 : 1;
  } else {
    //总数大于4
    if (point != num) {
      point = Number(point) + 1;
      let filte = list.filter((x) => x == point);
      if (filte.length <= 0) {
          list = arr.splice(point - 4, 4);
      }
    } else {
      point = 1;
      list = arr.splice(0, 4);
    }
  }
}
// 83
// UUDUDDDDUDUUDDDDUDD
// 3 4 5 6
// 6
// 109
// DDUUUDDUDUDUDDUDDDUUUUDUUUUUD
// 106 107 108 109
// 107

// 107
// UDDUUDUDDUUDDDDDDUUDUDDUUUU
// 2 3 4 5 
// 2

// 2
// DUDUDDUUDUDDDDUDUDDDUUDDUDDUDUDUDDDUDUDUUDDUUDDUUUDUDUUUDDUDUDDUUDUDDDDUDUDUUDUDDDDDUU
// 1 2 
// 1
全部评论

相关推荐

头像
11-09 12:17
清华大学 C++
out11Man:小丑罢了,不用理会
点赞 评论 收藏
分享
点赞 收藏 评论
分享
牛客网
牛客企业服务