【筆記】【JavaScript】JSchallenger-set對象-練習筆記

来源:https://www.cnblogs.com/lao-jiaweijarvee/archive/2022/04/23/16183126.html
-Advertisement-
Play Games

前言 【筆記內容】 關於JSchallenger中Set對象題目的復盤 本人的提交、以及做題時的思路 分析作者答案 涉及的知識快速瞭解,註意:並不深入分析具體知識,只是圍繞題目展開 【筆記目的】 幫助本人進一步瞭解Javascript的Set對象以及涉及的方法 對自己做題後的復盤,進一步瞭解自己的不 ...


前言

【筆記內容】

  • 關於JSchallenger中Set對象題目的復盤
  • 本人的提交、以及做題時的思路
  • 分析作者答案
  • 涉及的知識快速瞭解,註意:並不深入分析具體知識,只是圍繞題目展開

【筆記目的】

  • 幫助本人進一步瞭解Javascript的Set對象以及涉及的方法
  • 對自己做題後的復盤,進一步瞭解自己的不足之處

【相關資源】


溫馨提示

  • 筆記中有些個人理解後整理的筆記,可能有所偏差,也懇請讀者幫忙指出,謝謝。
  • 若是有其他的解題方法也請讀者分享到評論區,一起學習,共同進步,謝謝。
  • 我的提交有不足之處也懇請讀者幫忙指出,不吝賜教,謝謝。


Set對象快速瞭解

什麼是Set對象?

  • 允許你存儲任何類型的唯一值
  • 是值的集合,Set中的元素只會出現一次,即 Set 中的元素是唯一的。
  • 常見方法
方法名 描述
Set() 創建一個新的Set對象
Set.prototype.add() Set對象尾部添加一個元素。返回該Set對象。
Set.prototype.clear() 移除Set對象內的所有元素。
Set.prototype.has() has() 方法返回一個布爾值來指示對應的值value是否存在Set對象中。
Set.prototype.values() 返回一個新的迭代器對象,該對象包含Set對象中的按插入順序排列的所有元素的值

瞭解更多


JSchallenger Javascript Sets

Check if value is present in Set

需求:

Write a function that takes a Set and a value as arguments

Check if the value is present in the Set

我的提交(作者答案)

function myFunction(set, val) {
    return set.has(val);
}

涉及知識(set.has()方法)

Set.prototype.has()

  • 返回一個布爾值來指示對應的值value是否存在Set對象中。

格式

mySet.has(value);

value(需要測試的值):必須。用來判斷該值是否存在Set對象中

返回值

  • 布爾值。
    • true:存在
    • false:不存在

Convert a Set to Array

需求:

Write a function that takes a Set as argument

Convert the Set to an Array

Return the Array

我的提交

function myFunction(set) {
   return Array.from(set);
}

作者答案

function myFunction(set) {
  return [...set];
}

涉及知識(Set對象與數組對象的相互轉換、Array.from()方法、擴展運算符)

Set對象與數組對象的相互轉換

數組對象 ==>Set對象
var arr=[1,2,3]
var set = new Set(arr);
Set對象 ==>數組對象

Array.from()從set生成數組

var set = new Set([1,2,3]);
var arr = Array.from(set);

[ ]

var set = new Set([1,2,3]);
var arr = [...set];

PS:數組對象與Set對象的區別

Set對象 數組對象
元素 唯一 可重覆
數組 偽數組 真正數組


Array.from()方法

  • 創建數組對象

瞭解更多



擴展運算符

  • 又稱對象展開符,由...表示

  • 用於取出參數對象所有可遍歷屬性然後拷貝到當前對象。

    let person = {name: "Amy", age: 15};
    let someone = { ...person };
    someone;  //{name: "Amy", age: 15}
    

瞭解更多


Get union of two sets

需求:

Write a function that takes two Sets as arguments

Create the union of the two sets

Return the result

Tipp: try not to switch to Arrays, this would slow down your code

我的提交

function myFunction(a, b) {
   return new Set([...a, ...b]);
}

作者答案

function myFunction(a, b) {
  const result = new Set(a);
  b.forEach((el) => result.add(el));
  return result;
}

涉及知識(拼接兩個Set對象的方法、擴展運算符、forEach()方法、set.add()方法、箭頭函數)

拼接兩個Set對象的方法

方法一:通過拓展運算符,合併兩個偽數組

var a=new Set([1,2,3]);
var b=new Set([4,5,6]);
var arr = new Set([...a,...b]);

方法二:通過迴圈將一個Set對象中元素添加到另一個Set對象中

具體實現正如上述作者答案,就不在贅述了。



擴展運算符

  • 可用於合併兩個對象

    let age = {age: 15};
    let name = {name: "Amy"};
    let person = {...age, ...name};
    person;  //{age: 15, name: "Amy"}
    

點此瞭解更多



forEach()方法

  • 用於調用數組的每個元素,並將元素傳遞給回調函數。

格式(註意該格式不完整,之針對本題的格式

array.forEach(function(currentValue), thisValue)

functuion(currentValue)(數組中每個元素需要調用的函數):必需

  • currentValue(當前元素):必需

thisValue:可選

  • 傳遞給函數的值一般用 this 值。
  • 如果這個參數為空, undefined 會傳遞給 this

返回值undefined

瞭解更多



set.add()方法

  • 用來向一個 Set 對象的末尾添加一個指定的值。

格式

mySet.add(value);

value(需要添加到 Set 對象的元素的值):必需

返回值Set 對象本身

註意:不能添加重覆的值



箭頭函數

  • 使函數表達式更簡潔
  • 更適用於那些本來需要匿名函數的地方
  • 它不能用作構造函數

格式:

(param1, param2, …, paramN) => expression
(param1, param2, …, paramN) => { statements }
//相當於:(param1, param2, …, paramN) =>{ return expression; }

param:參數

expression:表達式

其他格式 前提
singleParam => { statements } 只有一個參數時,圓括弧是可選的:
() => { statements } 沒有參數的函數應該寫成一對圓括弧。

瞭解更多


Creating Javascript Sets

需求:

Write a function that takes three elements of any type as arguments

Create a Set from those elements

Return the result

我的提交

function myFunction(a, b, c) {
   return new Set([a,b,c])
}

作者答案

function myFunction(a, b, c) {
  const set = new Set();
  set.add(a);
  set.add(b);
  set.add(c);
  return set;
}

涉及知識(構建Set對象方法、set.add()方法)

構建Set對象方法

格式

var myset = new Set();

var myset = new Set(iterable);

iterable(可迭代對象):數組或類數組對象

【PS】可迭代對象是什麼?

就是可以重覆、改進、升級的對象

具體可以看這篇博客究竟什麼是迭代?



set.add()方法

之前解釋過就不再贅述了,點擊此處跳轉


Delete element from Set

需求:

Write a function that takes a Set and a value as argument

If existing in the Set, remove the value from the Set

Return the result

我的提交(作者答案)

function myFunction(set, val) {
   set.delete(val);
   return set;
}

涉及知識(set.delete()方法)

set.delete()

  • 可以從一個Set對象中刪除指定的元素

語法

mySet.delete(value);

value(將要刪除的元素)

返回值:布爾值

  • true:成功刪除
  • false:刪除失敗

Add multiple elements to Set

需求:

Write a function that takes a Set and an array as arguments

If not already existing, add each element in the array to the Set

Return the modified Set

我的提交

function myFunction(set, arr) {
   const set1=new Set(arr);
   return new Set([...set,...set1]);
}

【不足之處】

  • 需求要的是一個modified Set(修改過的Set)對象(即在原來的Set對象上修改),而不是新的Set對象。

作者答案

function myFunction(set, arr) {
  arr.forEach((e) => set.add(e));
  return set;
}

涉及知識(數組與Set對象拼接思路)

數組與Set對象拼接思路

思路一:

1、構建一個以數組元素為元素的Set對象

2、兩個Set對象拼接

思路二:

set.add()方法將數組元素一個加到Set對象中。


Get Intersection of two Javascript Sets

需求:

Write a function that takes two sets (a and b) as arguments

Get the intersection of the sets

In other words, return a set containing all elements that are both in a as well as b

我的提交

function myFunction(a, b) {
   return new Set([...a].filter(item=>b.has(item)));
}

作者答案

function myFunction(a, b) {
  const int = new Set();
  a.forEach(el => b.has(el) && int.add(el));
  return int;
}

涉及知識(array.filter()方法、Set對象取交集思路)

array.filter()方法

  • 創建一個新的數組,新數組中的元素是通過檢查指定數組中符合條件的所有元素。

註意

  • 不會對空數組進行檢測
  • 不會改變原始數組

格式(註意該格式不完整,之針對本題的格式

array.filter(function(currentValue))

functuion(currentValue)(數組中每個元素需要調用的函數):必需

  • currentValue(當前元素):必需

返回值

  • 數組:包含了符合條件的所有元素
  • 空數組:如果沒有符合條件的元素。

瞭解更多



Set對象取交集思路

思路一

1、先以處理數組交集的方法來處理

2、把數組轉換成Set對象

思路二

1、通過遍歷其中一個Set對象,逐個判斷另一個Set對象中也有的對象。

2、若有則加入新的Set對象中。


結語

【創作背景】

​ 偶然在抖音上刷到JSchallenger這個可以訓練Javascript基礎的網站,自己在完成所有的Schallenger題之後,想要通過博客來記錄自己的做題痕跡,以便日後快速回顧。原本打算把JSchallenger的所有題目以及分析整理成一篇博客發出來,但是我整理完後發現,已經快有1w多字,為了方便讀者和自己觀看,因此打算按照JSchallenger的板塊分開發佈。


【感謝】

感謝各位讀者能看到最後!!!


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

-Advertisement-
Play Games
更多相關文章
  • 一篇科普文章,介紹什麼是 Linux 信號,以及它的基本用法,內含精美圖表。 ...
  • MySQL 回表 五花馬,千金裘,呼兒將出換美酒,與爾同銷萬古愁。 一、簡述 回表,顧名思義就是回到表中,也就是先通過普通索引掃描出數據所在的行,再通過行主鍵ID 取出索引中未包含的數據。所以回表的產生也是需要一定條件的,如果一次索引查詢就能獲得所有的select 記錄就不需要回表,如果select ...
  • 分享嘉賓:高大月@美團點評,Apache Kylin PMC成員,Druid Commiter 編輯整理:Druid中國用戶組 6th MeetUp 出品平臺:DataFunTalk -- 導讀: 長久以來,對SQL和許可權的支持一直是Druid的軟肋。雖然社區早在0.9和0.12版本就分別添加了對S ...
  • Quantexa 服務特色是場景決策智能CDI(contextual decision intelligence) 主要落地場景是金融以及涉及交易的各類機構的反洗錢反金融詐騙, 客戶畫像, 風控 解決的問題是監管合規, 降低誤判率, 提高準確率, 降成本, 提高行業競爭力 面向的主要客戶是銀行, 保... ...
  • 一、Spark SQL概述 Spark SQL是Spark用來處理結構化數據的一個模塊,它提供了兩個編程抽象叫做DataFrame和DataSet並且作為分散式SQL查詢引擎的作用,其實也是對RDD的再封裝。大數據Hadoop之——計算引擎Spark,官方文檔:https://spark.apach ...
  • Q644F/Q645F氣動三通球閥是一種三通道的迴轉型球閥 用於介質分流、合流及流向切換,任何一個管道都可以作為入口或出口。氣動三通球閥分有氣動三通L型球閥和氣動三通T型球閥兩種,可以滿足不同的生產工藝要求。氣動三通L型球閥是對三條管道中的兩條管道進行切斷,氣動三通T型球閥實現把三條連通管道進行合流... ...
  • Q941F電動調節球閥適用於經常操作、兩位切斷、調節的場合。球閥與執行機構的連接採用直連方式,電動執行機構內置伺服系統,無須另配伺服放大器,輸入 4~20mA 信號及 220V AC 電源即可控制運轉。具有連線簡單,結構緊湊、尺寸小、重量輕、阻力小、動作穩定可靠等優點。執行機構可根據用戶要求配置不同... ...
  • 高平臺球閥主要用於截斷或接通介質,也可用於流體的調節與控制。與其它閥類相比,球閥具優點1、流體阻力小,球閥是所有閥類中流體阻力最小的一種,即使是縮徑球閥,其流體阻力也相當小。 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...