javascript測試題和參考答案----試題源自牛客網

附上牛客網鏈接:
https://www.nowcoder.com/ta/js-assessment?page=1
最近有點不知所措,該用什麼,該學什麼;隨意學起了javascript,就試着做了一下牛客網的試題,附上答案

  • 1、查找數組元素位置

題目描述 找出元素 item 在給定數組 arr 中的位置 輸出描述: 如果數組中存在 item,則返回元素在數組中的位置,否則返回 -1
示例1: 輸入 [ 1, 2, 3, 4 ], 3 輸出 2

參考代碼

function indexOf(arr, item) {
   for(var i in arr)
   {
       if(arr[i] == item)
       {
           return i;
       }
   }  
   return -1;
}
  • 2、數組求和

題目描述 計算給定數組 arr 中所有元素的總和 輸入描述: 數組中的元素均爲 Number 類型
示例1 輸入 [ 1, 2, 3, 4 ] 輸出 10

參考代碼

function sum(arr) {
   var value = 0;
    for(var i in arr)
    {
        value += arr[i];
    }

    return value;
}
  • 3、移除數組中的元素

題目描述 移除數組 arr 中的所有值與 item 相等的元素。不要直接修改數組 arr,結果返回新的數組
示例1
輸入 [1, 2, 3,4, 2], 2 輸出 [1, 3, 4]

參考代碼

function remove(arr, item) {
    var newarr = [];
    for(var i=0; i<arr.length; i++)
    {
        if(arr[i]!=item)
        {
            newarr.push(arr[i]);
        }
    }

    return newarr;
}
  • 4、.移除數組中的元素

題目描述
移除數組 arr 中的所有值與 item 相等的元素,直接在給定的 arr 數組上進行操作,並將結果返回
示例1
輸入 [1,2, 2, 3, 4, 2, 2], 2 輸出 [1, 3, 4]

參考代碼
重點留意一下i++在什麼時候執行。

function removeWithoutCopy(arr, item) {
    var i = 0;
    while(i<arr.length)
    {
        if(arr[i]==item)
        {
            arr.splice(i, 1);
        }else
        {
            i++;
        }
    }
    return arr;
}
  • 5、添加元素

題目描述
在數組 arr 末尾添加元素 item。不要直接修改數組 arr,結果返回新的數組
示例1 輸入 [1, 2, 3, 4], 10 輸出 [1, 2, 3, 4, 10]

參考代碼,留意不能直接用newarr=arr這樣賦值,否則會改變arr數組
function append(arr, item) {
var newarr = arr.slice(0, arr.length);
newarr.push(item);
return newarr;
}

  • 6、刪除數組最後一元素

題目描述
刪除數組 arr 最後一個元素。不要直接修改數組 arr,結果返回新的數組
示例1 輸入 [1, 2, 3, 4] 輸出 [1, 2, 3]

參考代碼

function truncate(arr) {

    return arr.slice(0, (arr.length>1)?(arr.length-1):0)
}
  • 7、添加元素

    題目描述
    在數組 arr 開頭添加元素 item。不要直接修改數組 arr,結果返回新的數組
    示例1 輸入 [1, 2, 3, 4], 10 輸出 [10, 1, 2, 3, 4]


參考代碼
function prepend(arr, item) {
    return [item].concat(arr);
}
  • 8、刪除數組第一個元素

題目描述
刪除數組 arr 第一個元素。不要直接修改數組 arr,結果返回新的數組
示例1 輸入 [1, 2, 3, 4] 輸出 [2,3, 4]

參考答案

function curtail(arr) {
    return arr.slice(1,arr.length);
}
  • 9、數組合並

題目描述
合併數組 arr1 和數組 arr2。不要直接修改數組 arr,結果返回新的數組
示例1 輸入 [1, 2, 3, 4],[‘a’, ‘b’, ‘c’, 1] 輸出 [1, 2, 3, 4, ‘a’, ‘b’, ‘c’, 1]

參考代碼

function concat(arr1, arr2) {

    return Array.prototype.concat(arr1, arr2);
}
  • 10、添加元素

題目描述
在數組 arr 的 index 處添加元素 item。不要直接修改數組 arr,結果返回新的數組
示例1 輸入 [1, 2, 3, 4], ‘z’, 2 輸出 [1, 2, ‘z’, 3, 4]

參考代碼

function insert(arr, item, index) {
    var newarr = arr.slice(0, arr.length);
    newarr.splice(index, 0, item);
    return newarr;
}
  • 11、計數

題目描述
統計數組 arr 中值等於 item 的元素出現的次數
示例1 輸入 [1, 2, 4, 4, 3, 4, 3], 4 輸出 3

參考代碼

function count(arr, item) {
  var c = 0;
  for(var i in arr)
  {
      if(item == arr[i])
      {
          c++;
      }
  }
  return c;
}
  • 12、查找重複元素

題目描述
找出數組 arr 中重複出現過的元素
示例1 輸入 [1, 2, 4, 4, 3, 3, 1, 5, 3] 輸出 [1, 3, 4]

參考代碼

function duplicates(arr) {
    var newarr = arr.slice(0, arr.length);
    var duparr = [];
    while(newarr.length)
    {
        var value = newarr[0]; 
        var index;
        var dup = false;
        newarr.splice(0,1);
        while((index=newarr.indexOf(value))!=-1)
        {
            newarr.splice(index,1);
            dup = true;
        }

        if(dup==true)
        {
            duparr.push(value);
        }

    }

   return duparr;
}
//代碼2
function duplicates(arr) {
    var duparr = arr.slice(0, arr.length);
    var i = 0;
    while(i< duparr.length)
    {
        var value = temparr[i];
        var index = 0;
        var dup = false;
        while((index = duparr.lastIndexOf(value))!= i)
        {
            duparr.splice(index, 1);
            dup = true;
        }
        if(dup == false)
        {
            duparr.splice(i, 1);
        }else
        {
            i++;
        }

    }

    return duparr;
}
  • 13、求二次方

題目描述
爲數組 arr 中的每個元素求二次方。不要直接修改數組 arr,結果返回新的數組
示例1 輸入 [1, 2, 3, 4] 輸出 [1, 4, 9, 16]

參考代碼

function square(arr) {
   var sq = [];  
   for(var i in arr)
  {
      sq.push(arr[i]*arr[i]);
  }
    return sq;
}
  • 14、查找元素位置

題目描述
在數組 arr 中,查找值與 item 相等的元素出現的所有位置
示例1 輸入 ‘abcdefabc’ 輸出 [0, 6]

參考代碼
注測試用例與題目描述有差異,所以用代碼1通不過測試

function findAllOccurrences(arr, target) {
  var pos = [];

    var p = 0;
    for(var i=0; i<arr.length; i++)
    {
        if(arr.charAt(i)==target)
        {
            pos.push(i);
        }
    }

    return pos;

}
//代碼2
function findAllOccurrences(arr, target) {
    var pos = [];  
    for(var i=0; i<arr.length; i++)
    {
        if(arr[i]==target)
        {
            pos.push(i);
        }
    }   
    return pos;     
}
  • 15、避免全局變量

題目描述
給定的 js 代碼中存在全局變量,請修復

function globals() {
    myObject = {
      name : 'Jory'
    };

    return myObject;
}
//修復後
function globals() {
   var myObject = {
      name : 'Jory'
    };

    return myObject;
}
  • 16、正確的函數定義

題目描述
請修復給定的 js 代碼中,函數定義存在的問題
示例1 輸入 true 輸出 a

原代碼

function functions(flag) {
    if (flag) {
      function getValue() { return 'a'; }
    } else {
      function getValue() { return 'b'; }
    }
    return getValue();
}

參考代碼
注:主要是考察函數兩種定義的理解:函數聲明和表達式,這個錯誤和瀏覽器有關並不是所有瀏覽器都會有問題。

function functions(flag) {
    if (flag) {
      var getValue = function() { return 'a'; }
    } else {
      var getValue = function() { return 'b'; }
    }
    return getValue();
}

17、正確使用parseInt

題目描述
修改 js 代碼中 parseInt 的調用方式,使之通過全部測試用例
示例1 輸入 ‘12’ 輸出 12
示例2 輸入 ‘12px’ 輸出12
示例3 輸入 ‘0x12’ 輸出 0

參考代碼

function parse2Int(num) {
    num = num.toLowerCase();
    num = num.replace("0x", "0a");
    return parseInt(num);
}
  • 18、完全相等

題目描述 判斷 val1 和 val2 是否完全等同

參考代碼

function identity(val1, val2) {
  return val1===val2;
}
  • 19、計時器

題目描述
實現一個打點計時器,要求
1、從 start 到 end(包含 start 和 end),每隔 100 毫秒console.log 一個數字,每次數字增幅爲 1
2、返回的對象中需要包含一個 cancel 方法,用於停止定時操作
3、第一個數需要立即輸出

參考代碼

function count(start, end) {
    var timestamp = null
    console.log(start);
    var addfunc = function(){
        if(start<end)
        {
            start++;
            console.log(start);
        }else
        {
            clearInterval(timestamp);
        }
    };
    timestamp = setInterval(addfunc,100);

    return {
        cancel:function(){
            clearInterval(timestamp);
        }
    }
}
  • 20、流程控制

題目描述
實現 fizzBuzz 函數,參數 num 與返回值的關係如下:
1、如果 num 能同時被 3 和 5 整除,返回字符串
fizzbuzz
2、如果 num 能被 3 整除,返回字符串 fizz
3、如果 num 能被 5 整除,返回字符串 buzz
4、如果參數爲空或者不是 Number 類型,返回 false 5、其餘情況,返回參數 num
示例1 輸入 15 輸出 fizzbuzz

參考代碼

function fizzBuzz(num) {
  if(typeof num != "number")
  {
      return false;
  }
  if(!(num%3)&&!(num%5))
  {
      return "fizzbuzz";
  }else if(!(num%3))
  {
      return "fizz";
  }else if(!(num%5))
  {
      return "buzz";
  }else
  {
      return num;
  }
}
  • 21、函數傳參

題目描述
將數組 arr 中的元素作爲調用函數 fn 的參數
示例1 輸入 function (greeting, name,punctuation) {return greeting + ‘, ’ + name + (punctuation || ‘!’);}, [‘Hello’, ‘Ellie’, ‘!’] 輸出 Hello, Ellie!

參考代碼

function argsAsArray(fn, arr) {
    return fn.apply(this, arr);
}
  • 22、函數上下文

題目描述
將函數 fn 的執行上下文改爲 obj 對象
示例1 輸入 function () {return this.greeting + ‘, ’ + this.name + ‘!!!’;}, {greeting: ‘Hello’, name: ‘Rebecca’} 輸出Hello, Rebecca!!!

參考代碼

function speak(fn, obj) {
   return fn.call(obj);
}
  • 23、返回函數

題目描述
實現函數 functionFunction,調用之後滿足如下條件:
1、返回值爲一個函數 f
2、調用返回的函數 f,返回值爲按照調用順序的參數拼接,拼接字符爲英文逗號加一個空格,即 ‘, ’
3、所有函數的參數數量爲 1,且均爲 String 類型
示例1 輸入 functionFunction(‘Hello’)(‘world’) 輸出 Hello, world

參考代碼

function functionFunction(str) {
    return function(newstr){
         var arr = [];
        arr.push(str);
        arr.push(" "+newstr);
        return arr.join(",");
    }
}
  • 24、使用閉包

題目描述
實現函數 makeClosures,調用之後滿足如下條件:
1、返回一個函數數組 result,長度與 arr 相同
2、運行 result 中第 i 個函數,即 resulti,結果與 fn(arr[i]) 相同
示例1 輸入 [1, 2, 3], function (x) { return x * x; } 輸出 4

參考代碼
這題相對有點難,在《Javascript 高級程序設計》中閉包部分有相關例子。

function makeClosures(arr, fn) {

    var result =[];
    for(var i=0; i<arr.length; i++)
    {
        result[i] = function(num)
        {
            return function()
            {
                return fn(num);
            }
        }(arr[i]);
    }
    return result;
}
  • 25、二次封裝

題目描述
已知函數 fn 執行需要 3 個參數。請實現函數 partial,調用之後滿足如下條件:
1、返回一個函數 result,該函數接受一個參數
2、執行 result(str3) ,返回的結果與 fn(str1, str2, str3) 一致
示例1 輸入var sayIt = function(greeting, name, punctuation) { return greeting + ‘, ’ + name + (punctuation || ‘!’); }; partial(sayIt, ‘Hello’, ‘Ellie’)(‘!!!’); 輸出
Hello, Ellie!!!

參考代碼

function partial(fn, str1, str2) {

    //var result = [];
    return function(str3){
        return fn(str1,str2, str3);
    }
}
  • 25、使用arguments

題目描述
函數 useArguments 可以接收 1 個及以上的參數。請實現函數
useArguments,返回所有調用參數相加後的結果。本題的測試參數全部爲 Number 類型,不需考慮參數轉換。
示例1 輸入 1, 2, 3, 4 輸出 10

參考代碼

function useArguments() {
   var sum = 0;
    for(var i in arguments)
   {
       sum += arguments[i];
   }
    return sum;
}
  • 26、使用apply調用函數

題目描述
實現函數 callIt,調用之後滿足如下條件
1、返回的結果爲調用 fn 之後的結果
2、fn 的調用參數爲 callIt 的第一個參數之後的全部參數
示例1 輸入 無 輸出 無

參考代碼

function callIt(fn) {
    var args = Array.prototype.slice.call(arguments,1);
    return fn.apply(null,args);   
}
  • 27、二次封裝函數

題目描述
實現函數 partialUsingArguments,調用之後滿足如下條件:
1、返回一個函數 result
2、調用 result 之後,返回的結果與調用函數 fn 的結果一致
3、fn 的調用參數爲 partialUsingArguments 的第一個參數之後的全部參數以及 result 的調用參數
示例1 輸入:無,輸出:無

function partialUsingArguments(fn) {
    var args1 = Array.prototype.slice.call(arguments, 1);
    return function(){ 
        return fn.apply(this, args1.concat([].slice.call(arguments)));
    }
}

28、柯里化

題目描述
已知 fn 爲一個預定義函數,實現函數 curryIt,調用之後滿足如下條件:
1、返回一個函數 a,a 的 length 屬性值爲 1(即顯式聲明 a 接收一個參數)
2、調用 a 之後,返回一個函數 b, b 的 length 屬性值爲 1
3、調用 b 之後,返回一個函數 c, c 的 length 屬性值爲 1
4、調用 c 之後,返回的結果與調用 fn 的返回值一致
5、fn 的參數依次爲函數 a, b, c 的調用參數
示例1
輸入var fn = function (a, b, c) {return a + b + c}; curryIt(fn)(1)(2)(3);
輸出6

參考代碼

function curryIt(fn) {
   return function(a)
   {
       return function(b)
       {
           return function(c)
           {
               return fn(a,b,c);
           }
       }
   }
}
  • 29、或運算

題目描述
返回參數 a 和 b 的邏輯或運算結果
示例1
輸入
false, true
輸出
true

參考代碼:

function or(a, b) {
    return a||b;
}
  • 30、且運算

題目描述
返回參數 a 和 b 的邏輯且運算結果
示例1
輸入
false, true
輸出
false

參考代碼:

function and(a, b) {

    return a&&b;
}
  • 31、模塊

題目描述
完成函數 createModule,調用之後滿足如下要求:
1、返回一個對象
2、對象的 greeting 屬性值等於 str1, name 屬性值等於 str2
3、對象存在一個 sayIt 方法,該方法返回的字符串爲 greeting屬性值 + ‘, ’ + name屬性值

參考代碼:*
*注意網站上面要求逗號後要有空格,否則通不過,即”,空格”

function createModule(str1, str2) {

    return {
        greeting:str1,
        name:str2,
        sayIt:function()
        {
            return this.greeting+", "+this.name;
        }
    }
}
  • 32、二進制轉換

題目描述
獲取數字 num 二進制形式第 bit 位的值。注意:
1、bit 從 1 開始
2、返回 0 或 1
3、舉例:2 的二進制爲 10,第 1 位爲 0,第 2 位爲 1
示例1
輸入
128, 8
輸出
1

參考代碼:

function valueAtBit(num, bit) {
     var str = num.toString(2);
    return str.charAt(str.length-bit);
}
  • 33、二進制轉換

題目描述
給定二進制字符串,將其換算成對應的十進制數字
示例1
輸入
‘11000000’
輸出
192

參考代碼:

function base10(str) {

    var num = 0;
    for(var i=0; i<str.length;i++)
   {
       var bit = str.charAt(i);
       num |= (bit<<(str.length-i-1));
   }
    return num;
}
  • 34、二進制轉換

題目描述
將給定數字轉換成二進制字符串。如果字符串長度不足 8 位,則在前面補 0 到滿8位。
示例1
輸入
65
輸出
01000001

參考代碼:

function convertToBinary(num) {
    var str = num.toString(2);
    for(var i=str.length; i<8; i++)
    {
        str = "0"+str;
    }
    return str;
}
  • 35、乘法

題目描述
求 a 和 b 相乘的值,a 和 b 可能是小數,需要注意結果的精度問題
示例1
輸入
3, 0.0001
輸出
0.0003

參考代碼:此例能通過網站測試,但不完善,建議看網站別人的答案

function multiply(a, b) {
   return a*b;
}
  • 36、改變上下文

題目描述
將函數 fn 的執行上下文改爲 obj,返回 fn 執行後的值
示例1
輸入
alterContext(function() {return this.greeting + ‘, ’ + this.name + ‘!’; }, {name: ‘Rebecca’, greeting: ‘Yo’ })
輸出
Yo, Rebecca!

參考代碼:

function alterContext(fn, obj) {
    return fn.call(obj);
}
  • 37、批量改變對象屬性

題目描述
給定一個構造函數 constructor,請完成 alterObjects 方法,將 constructor 的所有實例的 greeting 屬性指向給定的 greeting 變量。
示例1
輸入
var C = function(name) {this.name = name; return this;};
var obj1 = new C(‘Rebecca’);
alterObjects(C, ‘What\’s up’); obj1.greeting;
輸出
What’s up

參考代碼:

function alterObjects(constructor, greeting) {
    constructor.prototype.greeting = greeting;
}
  • 38、屬性遍歷

題目描述
找出對象 obj 不在原型鏈上的屬性(注意這題測試例子的冒號後面也有一個空格~)
1、返回數組,格式爲 key: value
2、結果數組不要求順序
示例1
輸入
var C = function() {this.foo = ‘bar’; this.baz = ‘bim’;};
C.prototype.bop = ‘bip’;
iterate(new C());
輸出
[“foo: bar”, “baz: bim”]

參考代碼:樣例來源於牛客網

function iterate(obj) {
        var arr = [];
        for (var x in obj) {
            if (!(x in obj.\__proto__)){
                arr.push(x + ": " + obj[x]);
            }
        }
        return arr;
    }
  • 39、判斷是否包含數字

題目描述
給定字符串 str,檢查其是否包含數字,包含返回 true,否則返回 false
示例1
輸入
‘abc123’
輸出
true

參考代碼:

function containsNumber(str) {
   return str.match("[0-9]")!=null;
}
  • 40、檢查重複字符串

題目描述
給定字符串 str,檢查其是否包含連續重複的字母(a-zA-Z),包含返回 true,否則返回 false
示例1
輸入
‘rattler’
輸出
true

參考代碼:代碼源自牛客網

function containsRepeatingLetter(str) {
     return /([a-zA-Z])\1/.test(str);
 }
  • 41、判斷是否以元音字母結尾

題目描述
給定字符串 str,檢查其是否以元音字母結尾
1、元音字母包括 a,e,i,o,u,以及對應的大寫
2、包含返回 true,否則返回 false
示例1
輸入
‘gorilla’
輸出
true
參考代碼:

function endsWithVowel(str) {
    var partten = "[aeiouAEIOU]$"
    return(str.match(partten)!=null);
}
  • 42、獲取指定字符串

題目描述
給定字符串 str,檢查其是否包含 連續3個數字
1、如果包含,返回最新出現的 3 個數字的字符串
2、如果不包含,返回 false
示例1
輸入
‘9876543’
輸出
987
參考代碼:

function captureThreeNumbers(str) {

  var result = str.match(/\d{3}/);
  if(result)
  {
      return result[0];

  }else
  {
      return false;
  }
}
  • 43、判斷是否符合指定格式

題目描述
給定字符串 str,檢查其是否符合如下格式
1、XXX-XXX-XXXX
2、其中 X 爲 Number 類型
示例1
輸入
‘800-555-1212’
輸出true

參考代碼

function matchesPattern(str) {
    return (/^\d{3}\-\d{3}\-\d{4}$/).test(str);
}
  • 44、判斷符合USD格式

題目描述
給定字符串 str,檢查其是否符合美元書寫格式
1、以 $ 開始
2、整數部分,從個位起,滿 3 個數字用 , 分隔
3、如果爲小數,則小數部分長度爲 2
4、正確的格式如:$1,023,032.03 或者 $2.03,錯誤的格式如:$3,432,12.12 或者 $34,344.3
示例1
輸入
‘$20,933,209.93’
輸出
true

參考代碼
代碼源自牛客網

function isUSD(str) {
    var re = /^\$([1-9]\d{0,2}(,\d{3})*|0)(\.\d{2})?$/;
    return re.test(str);
}
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章