2020-09-29 22:09:05 +02:00

2.7 KiB
Raw Blame History

id, title, challengeType, videoUrl, forumTopicId, localeTitle
id title challengeType videoUrl forumTopicId localeTitle
56533eb9ac21ba0edf2244c6 Stand in Line 1 https://scrimba.com/c/ca8Q8tP 18307 排队

Description

在计算机科学中队列queue是一个抽象的数据结构队列中的条目都是有秩序的。新的条目会被加到队列的末尾,旧的条目会从队列的头部被移出。 写一个函数nextInLine,用一个数组(arr)和一个数字(item)作为参数。 把数字添加到数组的结尾,然后移出数组的第一个元素。 最后nextInLine函数应该返回被删除的元素。

Instructions

Tests

tests:
  - text: <code>nextInLine([], 5)</code>应该返回一个数字。
    testString: assert.isNumber(nextInLine([],5));
  - text: <code>nextInLine([], 1)</code>应该返回<code>1</code>。
    testString: assert(nextInLine([],1) === 1);
  - text: <code>nextInLine([2], 1)</code>应该返回<code>2</code>。
    testString: assert(nextInLine([2],1) === 2);
  - text: <code>nextInLine([5,6,7,8,9], 1)</code>应该返回<code>5</code>。
    testString: assert(nextInLine([5,6,7,8,9],1) === 5);
  - text: 在<code>nextInLine(testArr, 10)</code>执行后<code>testArr[4]</code>应该是<code>10</code>。
    testString: nextInLine(testArr, 10); assert(testArr[4] === 10);

Challenge Seed

function nextInLine(arr, item) {
  // Your code here

  return item;  // Change this line
}

// Test Setup
var testArr = [1,2,3,4,5];

// Display Code
console.log("Before: " + JSON.stringify(testArr));
console.log(nextInLine(testArr, 6)); // Modify this line to test
console.log("After: " + JSON.stringify(testArr));

Before Test

var logOutput = [];
var originalConsole = console
function capture() {
    var nativeLog = console.log;
    console.log = function (message) {
        logOutput.push(message);
        if(nativeLog.apply) {
          nativeLog.apply(originalConsole, arguments);
        } else {
          var nativeMsg = Array.prototype.slice.apply(arguments).join(' ');
          nativeLog(nativeMsg);
        }
    };
}

function uncapture() {
  console.log = originalConsole.log;
}

capture();

After Test

uncapture();
testArr = [1,2,3,4,5];
(function() { return logOutput.join("\n");})();

Solution

var testArr = [ 1,2,3,4,5];

function nextInLine(arr, item) {
    arr.push(item);
    return arr.shift();
}