基礎複習1

来源:https://www.cnblogs.com/angle-xiu/archive/2020/06/28/13204682.html
-Advertisement-
Play Games

基礎回顧1 查找元素位置 題目描述:找出元素 item 在給定數組 arr 中的位置 輸出描述: 如果數組中存在 item,則返回元素在數組中的位置,否則返回 -1 function indexOf(arr, item) { if(Array.prototype.indexOf) return ar ...


基礎回顧1

  1. 查找元素位置
  • 題目描述:找出元素 item 在給定數組 arr 中的位置
  • 輸出描述: 如果數組中存在 item,則返回元素在數組中的位置,否則返回 -1
    function indexOf(arr, item) {
    if(Array.prototype.indexOf)
        return arr.indexOf(item);
    for(let i = 0; i < arr.length; i++){
        if(item === arr[i])
            return i;
    }
    return -1;
}
  1. 數組求和
  • 題目描述 計算給定數組 arr 中所有元素的總和
  • 輸出描述 數組中的元素均為 Number 類型
    function sum(arr) {
   return arr.reduce(function(pre,next){
        return pre+next;
    },0)
}
  1. 移除數組元素
  • 題目描述 移除數組 arr 中的所有值與 item 相等的元素。不要直接修改數組 arr,結果返回新的數組
    function remove(arr, item) {
    return arr.filter(function(item1){
        return item1 !== item;
    })
}
  1. 移除數組的元素
  • 題目描述 移除數組 arr 中的所有值與 item 相等的元素,直接在給定的 arr 數組上進行操作,並將結果返回
  • 輸出描述
    function removeWithoutCopy(arr, item) {
    for(var i=0;i<arr.length;i++){
      var a=arr.indexOf(item);
      arr.splice(a,1);
    }
    return arr;
}
  1. 添加元素
  • 題目描述 在數組 arr 末尾添加元素 item。不要直接修改數組 arr,結果返回新的數組
    function append(arr, item) {
    let newarr = arr.slice(0);
    newarr.push(item);
    return newarr;
}
  1. 刪除數組最後一個元素
  • 題目描述 刪除數組 arr 最後一個元素。不要直接修改數組 arr,結果返回新的數組
    function truncate(arr) {
    return arr.slice(0,-1);
}
  1. 添加元素
  • 題目描述 在數組 arr 開頭添加元素 item。不要直接修改數組 arr,結果返回新的數組
  • 輸出描述
    function prepend(arr, item) {
    let newarr = [];
    newarr[0] = item;
    arr.forEach(function(item1,index){
        newarr[index+1] = item1;
    })
    return newarr;
}
  1. 刪除數組第一個元素
  • 題目描述 刪除數組 arr 第一個元素。不要直接修改數組 arr,結果返回新的數組
  • 輸出描述
    function curtail(arr) {
    let newarr = arr.slice(0);
     newarr.shift();
    return newarr;
}
  1. 數組合併
  • 題目描述 合併數組 arr1 和數組 arr2。不要直接修改數組 arr,結果返回新的數組
    function concat(arr1, arr2) {
    let a = [];
    return a.concat(arr1,arr2);
}
  1. 添加元素
  • 題目描述 在數組 arr 的 index 處添加元素 item。不要直接修改數組 arr,結果返回新的數組
  • 輸出描述
    function insert(arr, item, index) {
    let newarr = [];
    let newarr1 = arr.slice(0,index);//獲取數組前半段
    newarr1.push(item);//添加至數組前段
    let newarr2 = arr.slice(index);//獲取數組後半段
    return newarr.concat(newarr1,newarr2);//進行數組拼接
}
  1. 計數
  • 題目描述 統計數組 arr 中值等於 item 的元素出現的次數
  • 輸出描述
    function count(arr, item) {
    let count = 0;
    arr.forEach(function(item1){
        if(item1==item)
            count++;
    })
    return count;
}
  1. 查找重覆元素
  • 題目描述 找出數組 arr 中重覆出現過的元素
  • 輸出描述
    function duplicates(arr) {
    let obj = {};
    let newarr = [];
    arr.forEach(function(item){
        if(!obj[item])
            obj[item] = item;
        else if(!newarr.includes(item))
            newarr.push(item);
    })
    return newarr.sort();
}
  1. 求二次方
  • 題目描述 為數組 arr 中的每個元素求二次方。不要直接修改數組 arr,結果返回新的數組
  • 輸出描述
    function square(arr) {
    return arr.map(function(item){
        return item*item;
    })
}
  1. 查找元素位置
  • 題目描述 在數組 arr 中,查找值與 item 相等的元素出現的所有位置
  • 輸出描述
    function findAllOccurrences(arr, target) {
    let newarr = [];
    arr.forEach(function(item,index){
        if(item === target)
            newarr.push(index);
    })
    return newarr;
}
  1. 全局變數
  • 題目描述 給定的 js 代碼中存在全局變數,請修複
    function globals() {
    myObject = {//未聲明,預設為全局變數
      name : 'Jory'
    };

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

    return myObject;
}
  1. 正確的函數定義
  • 題目描述 請修複給定的 js 代碼中,函數定義存在的問題
  • 輸出描述
    function functions(flag) {
    if (flag) {
      function getValue() { return 'a'; }//在判斷語句塊中應使用函數表達式定義函數,而不用函數聲明的方式
    } else {
      function getValue() { return 'b'; }
    }

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

    return getValue();
}
  1. 正確使用parseInt
  • 題目描述 修改 js 代碼中 parseInt 的調用方式,使之通過全部測試用例
  • 測試用例
    • 輸入 '12'
    • 輸出 12
    • 輸入 0x21
    • 輸出 0
    function parse2Int(num) {
    return parseInt(num);//根據測試用例,發現是以10為基數進行解析,預設按字元串來確定基數
}
    function parse2Int(num) {
    return parseInt(num,10);
}
  1. 完全相同(考察絕對相等與相對相等)
  • 題目描述 判斷 val1 和 val2 是否完全等同
  • 輸出描述
    function identity(val1, val2) {
    return val1 === val2;
}
  1. 計時器
  • 題目描述 實現一個打點計時器,要求
    1、從 start 到 end(包含 start 和 end),每隔 100 毫秒 console.log 一個數字,每次數字增幅為 1
    2、返回的對象中需要包含一個 cancel 方法,用於停止定時操作
    3、第一個數需要立即輸出
    function count(start, end) {
  //立即輸出第一個值
  console.log(start++);
     var timer = setInterval(function(){
         if(start <= end){
             console.log(start++);
         }else{
             clearInterval(timer);
         }
     },100);
    //返回一個對象
     return {
         cancel : function(){
             clearInterval(timer);
         }
     };
 }

  1. 流程式控制制
  • 題目描述 實現 fizzBuzz 函數,參數 num 與返回值的關係如下:
    1、如果 num 能同時被 3 和 5 整除,返回字元串 fizzbuzz
    2、如果 num 能被 3 整除,返回字元串 fizz
    3、如果 num 能被 5 整除,返回字元串 buzz
    4、如果參數為空或者不是 Number 類型,返回 false
    5、其餘情況,返回參數 num
    function fizzBuzz(num) {
    if(!num|typeof(num)!=='number')
        return false;
    else if(num%3==0&&num%5==0)
        return 'fizzbuzz';
    else if(num%3==0)
        return 'fizz';
    else if(num%5==0)
        return 'buzz';
    else
    return num;
}
  1. 函數傳參
  • 題目描述 將數組 arr 中的元素作為調用函數 fn 的參數
  • 輸出描述
    function argsAsArray(fn, arr) {
    return fn(...arr);//es6語法
}
  1. 函數的上下文
  • 題目描述 將函數 fn 的執行上下文改為 obj 對象
    function speak(fn, obj) {
   return fn.bind(obj)();//也可使用call或者apply    
}
  1. 返回函數(考察閉包)
  • 題目描述 實現函數 functionFunction,調用之後滿足如下條件:
    1、返回值為一個函數 f
    2、調用返回的函數 f,返回值為按照調用順序的參數拼接,拼接字元為英文逗號加一個空格,即 ', '
    3、所有函數的參數數量為 1,且均為 String 類型
  • 輸出描述
    function functionFunction(str) {
    return function(str2){
        return str+', '+str2;
    }
}
  1. 使用閉包
  • 題目描述 實現函數 makeClosures,調用之後滿足如下條件:
    1、返回一個函數數組 result,長度與 arr 相同
    2、運行 result 中第 i 個函數,即 resulti,結果與 fn(arr[i]) 相同
    function makeClosures(arr, fn) {
    let result = [];
    for(let i=0; i<arr.length; i++)
    {
        result.push(function(e){
            return function(){
                return fn(e);
            }
        }(arr[i]));
    }
    return result;
}
  1. 二次封裝函數
  • 題目描述 已知函數 fn 執行需要 3 個參數。請實現函數 partial,調用之後滿足如下條件:
    1、返回一個函數 result,該函數接受一個參數
    2、執行 result(str3) ,返回的結果與 fn(str1, str2, str3) 一致
  • 輸出描述
    function partial(fn, str1, str2) {
    return function(str3){
        return fn(str1,str2,str3);
    }
}
  1. 使用arguments
  • 題目描述 函數 useArguments 可以接收 1 個及以上的參數。請實現函數 useArguments,返回所有調用參數相加後的結果。本題的測試參數全部為 Number 類型,不需考慮參數轉換。
  • 輸出描述
    function useArguments() {
    let arr = [...new Set(arguments)];
    return arr.reduce(function(pre,next){
        return pre+next;
    })    
}
  1. 使用apply調用函數
  • 題目描述 實現函數 callIt,調用之後滿足如下條件
    1、返回的結果為調用 fn 之後的結果
    2、fn 的調用參數為 callIt 的第一個參數之後的全部參數
  • 輸出描述
    function callIt(fn) {
    return fn.call(this,...[].slice.call(arguments,1));//轉化成數組並使用...將數組轉成單個的參數
}
  1. 二次封裝函數
  • 題目描述 實現函數 partialUsingArguments,調用之後滿足如下條件:
    1、返回一個函數 result
    2、調用 result 之後,返回的結果與調用函數 fn 的結果一致
    3、fn 的調用參數為 partialUsingArguments 的第一個參數之後的全部參數以及 result 的調用參數
    function partialUsingArguments(fn) {
    let arg1 = [].slice.call(arguments,1);
    let result = function(){
        return fn.apply(null,arg1.concat([].slice.call(arguments)))
    };
    return result;
}
  1. 柯里化
  • 題目描述 已知 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 的調用參數
    function curryIt(fn) {
    let n = fn.length;
    let arr = [];
    return function(arg){
        arr.push(arg);
        if(arr.length<n)
            return arguments.callee;
        else
            return fn.apply(null,arr);
    }
}

  1. 或運算
  • 題目描述 返回參數 a 和 b 的邏輯或運算結果
  • 輸出描述
    function or(a, b) {
    return a||b;
}
  1. 且運算
  • 題目描述 返回參數 a 和 b 的邏輯且運算結果
  • 輸出描述
    function and(a, b) {
    return a&&b;
}
  1. 模塊
  • 題目描述 完成函數 createModule,調用之後滿足如下要求:
    1、返回一個對象
    2、對象的 greeting 屬性值等於 str1, name 屬性值等於 str2
    3、對象存在一個 sayIt 方法,該方法返回的字元串為 greeting屬性值 + ', ' + name屬性值
    function createModule(str1, str2) {
    return {
        greeting:str1,
        name:str2,
        sayIt(){
            return this.greeting+", "+this.name;
        }
    }
}
  1. 二進位轉換
  • 題目描述 獲取數字 num 二進位形式第 bit 位的值。註意:
    1、bit 從 1 開始
    2、返回 0 或 1
    3、舉例:2 的二進位為 10,第 1 位為 0,第 2 位為
  • 輸出描述
    function valueAtBit(num, bit) {
    return (num>>(bit-1))&1
}
  1. 二進位轉換
  • 題目描述 給定二進位字元串,將其換算成對應的十進位數字
  • 輸出描述
    function base10(str) {
    return parseInt(str,2);
}
  1. 二進位轉換
  • 題目描述 將給定數字轉換成二進位字元串。如果字元串長度不足 8 位,則在前面補 0 到滿8位。
  • 輸出描述
    function convertToBinary(num) {
    let newnum = num.toString(2);
    if(newnum.length<8){
        for(let i = 0; i < 8-newnum.length; i++){
            newnum = '0'+newnum;
        }
        return newnum;
    }else
        return newnum;
}
  1. 乘法
  • 題目描述 求 a 和 b 相乘的值,a 和 b 可能是小數,需要註意結果的精度問題
  • 輸出描述
    function multiply(a, b) {
    var aDec = a.toString().split('.')[1] || '';
    var bDec = b.toString().split('.')[1] || '';
    var fix = aDec.length  + bDec.length;
    return (a * b).toFixed(fix);
}
  1. 改變上下文
  • 題目描述 將函數 fn 的執行上下文改為 obj,返回 fn 執行後的值
  • 輸出描述
    function alterContext(fn, obj) {
    return fn.call(obj);
}
  1. 批量改變對象屬性
  • 題目描述 給定一個構造函數 constructor,請完成 alterObjects 方法,將 constructor 的所有實例的 greeting 屬性指向給定的 greeting 變數。
  • 輸出描述
    function alterObjects(constructor, greeting) {
    constructor.prototype.greeting = greeting;
}
  1. 屬性遍歷(Object,keys()只能遍歷自身屬性,for in才能遍歷原型鏈上的屬性)
  • 題目描述 找出對象 obj 不在原型鏈上的屬性(註意這題測試例子的冒號後面也有一個空格~)
    1、返回數組,格式為 key: value
    2、結果數組不要求順序
    function iterate(obj) {
    let arr1 = Object.keys(obj);
    let arr2 = [];
    arr1.forEach(function(item){
        arr2.push(item+': '+obj[item]);
    });
    return arr2;
    
}
  1. 判斷是否包含數字(考察正則)
  • 題目描述 給定字元串 str,檢查其是否包含數字,包含返回 true,否則返回 false
  • 輸出描述
    
  • 題目描述
  • 輸出描述
    function containsNumber(str) {
    let reg = /\d/;
    return reg.test(str);
}
  1. 檢查重覆字元串(正則的反向引用)
  • 題目描述 給定字元串 str,檢查其是否包含連續重覆的字母(a-zA-Z),包含返回 true,否則返回 false
  • 輸出描述
    function containsRepeatingLetter(str) {
    return /([a-zA-Z])\1/.test(str);
}
  1. 判斷是否母音字母結尾
  • 題目描述 給定字元串 str,檢查其是否以母音字母結尾
    1、母音字母包括 a,e,i,o,u,以及對應的大寫
    2、包含返回 true,否則返回 false
    function endsWithVowel(str) {
    return /[a,e,i,o,u]/i.test(str[str.length-1]);
}
  1. 判斷是否符合格式
  • 題目描述 給定字元串 str,檢查其是否符合如下格式
    1、XXX-XXX-XXXX
    2、其中 X 為 Number 類型
    function matchesPattern(str) {
    let reg = /^(\d{3})-(\d{3})-(\d{4})$/g;
    return reg.test(str);
}
  1. 是否符合USD格式
  • 題目描述 給定字元串 str,檢查其是否符合美元書寫格式
    1、以 $ 開始
    2、整數部分,從個位起,滿 3 個數字用 , 分隔
    3、如果為小數,則小數部分長度為 2
    4、正確的格式如:$1,023,032.03 或者 $2.03,錯誤的格式如:$3,432,12.12 或者 $34,344.3
    function isUSD(str) {
    let reg = /^\$([1-9]\d{0,2}(,\d{3})*|0)(\.\d{2})?$/;
    return reg.test(str);
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 第一種形式: decode(條件,值1,返回值1,值2,返回值2,…值n,返回值n,預設值) ​ 實現數據的彙總: 源數據: ​ 彙總後的數據:使用decode函數處理數據後對dname欄位進行彙總。 ​ 第二種形式: decode(欄位或欄位的運算,值1,值2,值3);當欄位或欄位的運算的值等於值 ...
  • 1、coalesce函數的用法 1.1 取出第一個不為空的列的數據。 ​ 1.2 coalesce函數裡面的數據類型,必須全部都跟第一列的數據類型一致。 ​ 原因為第一個參數為數值,第二個參數為字元串;可通過轉換數據類型來使用,如下圖: ​ ...
  • 一、隱式Intent 1.如何配置 AndroidManifest.xml配置intent-filter內容 響應actioncom.example.activitytest.ACTION_START並且響應category才可以 在FirstActivity.java中進行設置Intent. 每個 ...
  • 前言: 這是許多矽谷公司用來衡量iOS候選人資歷水平的一系列問題。 這些問題涉及iOS開發的各個方面,旨在觸及對平臺的廣泛理解。 畢竟,高級開發人員應該能夠從頭到尾地發佈完整的iOS產品。 這絕不是一個詳盡的列表,但它可以幫助你為即將到來的技術iOS面試做準備。 目錄 你使用的最新版本的iOS是什麼 ...
  • Charles安裝 HTTP抓包 HTTPS抓包 1. Charles安裝 官網下載安裝Charles: https://www.charlesproxy.com/download/ 2. HTTP抓包 (1)查看電腦IP地址 (2)設置手機HTTP代理 手機連上電腦,點擊“設置->無線區域網->連 ...
  • 最近在這裡總結一些iOS開發中的小技巧,能大大方便我們的開發。 UITableView的Group樣式下頂部空白處理 //分組列表頭部空白處理 UIView *view = [[UIView alloc] initWithFrame:CGRectMake(0, 0, 0, 0.1)]; self.t ...
  • 前端知識 web服務的本質: 基於B/S網路架構,瀏覽器和服務端的交互 瀏覽器發送請求,服務端接收請求,服務端響應請求,服務端吧HTML文件內容發給瀏覽器,瀏覽器渲染頁面 發送請求通過OSI網路七層模型:應用層,表示層,會話層,傳輸層,網路層,數據鏈路層,物理層 一、HTML介紹 html是超文本標 ...
  • 提到HTML標簽,我們會非常熟悉,開發中經常使用。但我們往往關註更多的是頁面渲染效果及交互邏輯,也就是對用戶可見可操作的部分,比如表單、菜單欄、列表、圖文等。其實還有一些非常重要卻容易忽視的標簽,這些標簽大多數用在頁面頭部head標簽內,雖然對用戶不可見,但如果在某些場景下,比如交互實現、性能優化、 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...