freeCodeCamp/curriculum/challenges/chinese-traditional/02-javascript-algorithms-an.../basic-javascript/stand-in-line.md

2.3 KiB

id title challengeType videoUrl forumTopicId dashedName
56533eb9ac21ba0edf2244c6 排隊 1 https://scrimba.com/c/ca8Q8tP 18307 stand-in-line

--description--

在計算機科學中隊列(queue)是一個抽象的數據結構(Data Structure),隊列中的條目都是有秩序的。 新的條目會被加到隊列的末尾,舊的條目會從隊列的頭部被移出。

寫一個函數 nextInLine,用一個數組(arr)和一個數字(item)作爲參數。

把數字添加到數組的結尾,然後移出數組的第一個元素。

最後 nextInLine 函數應該返回被刪除的元素。

--hints--

nextInLine([], 5) 應該返回一個數字。

assert.isNumber(nextInLine([], 5));

nextInLine([], 1) 應該返回 1

assert(nextInLine([], 1) === 1);

nextInLine([2], 1) 應該返回 2

assert(nextInLine([2], 1) === 2);

nextInLine([5,6,7,8,9], 1) 應該返回 5

assert(nextInLine([5, 6, 7, 8, 9], 1) === 5);

nextInLine(testArr, 10) 執行後 testArr[4] 應該是 10

nextInLine(testArr, 10);
assert(testArr[4] === 10);

--seed--

--before-user-code--

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-user-code--

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

--seed-contents--

function nextInLine(arr, item) {
  // Only change code below this line

  return item;
  // Only change code above this line


}

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

// Display code
console.log("Before: " + JSON.stringify(testArr));
console.log(nextInLine(testArr, 6));
console.log("After: " + JSON.stringify(testArr));

--solutions--

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

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