题解 | #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