」工欲善其事,必先利其器。「—孔子《論語.錄靈公》
首頁 > 程式設計 > Typescript 編碼編年史: Self 以外的陣列的乘積

Typescript 編碼編年史: Self 以外的陣列的乘積

發佈於2024-07-31
瀏覽:762

Typescript Coding Chronicles: Product of Array Except Self

问题陈述:

给定一个整数数组nums,返回一个数组answer,使得answer[i]等于除nums[i]之外的nums所有元素的乘积。

nums 的任何前缀或后缀的乘积保证适合 32 位整数。

您必须编写一个在 O(n) 时间内运行且不使用除法运算的算法。

示例1:

  • 输入:nums = [1,2,3,4]
  • 输出:[24,12,8,6]

示例2:

  • 输入:nums = [-1,1,0,-3,3]
  • 输出:[0,0,9,0,0]

限制条件:

  • 2
  • -30
  • nums 的任何前缀或后缀的乘积保证适合 32 位整数。

跟进:

你能以 O(1) 额外的空间复杂度解决这个问题吗? (输出数组不计为空间复杂度分析的额外空间。)

初步思考过程:

为了解决这个问题,我们需要计算除当前元素之外的所有元素的乘积,而不使用除法运算。这可以通过对数组使用两次传递来完成:

  1. 计算每个元素的前缀积。
  2. 计算每个元素的后缀乘积并与前缀乘积相乘。

基本解决方案:

我们可以用两个数组来存储前缀和后缀的乘积,然后将它们相乘得到最终的结果。

代码:

function productExceptSelf(nums: number[]): number[] {
    const n = nums.length;
    const prefixProducts = new Array(n).fill(1);
    const suffixProducts = new Array(n).fill(1);
    const result = new Array(n).fill(1);

    // Compute prefix products
    for (let i = 1; i = 0; i--) {
        suffixProducts[i] = suffixProducts[i   1] * nums[i   1];
    }

    // Compute the result by multiplying prefix and suffix products
    for (let i = 0; i 



时间复杂度分析:

  • 时间复杂度: O(n),其中n是数组的长度。我们迭代数组三次。
  • 空间复杂度: O(n),用于存储前后缀乘积。

限制:

基本解决方案效果很好,但使用额外的空间来存储前缀和后缀产品。

优化方案:

我们可以优化解决方案以使用 O(1) 额外空间,方法是使用输出数组首先存储前缀产品,然后就地修改它以包含后缀产品。

代码:

function productExceptSelfOptimized(nums: number[]): number[] {
    const n = nums.length;
    const result = new Array(n).fill(1);

    // Compute prefix products in the result array
    for (let i = 1; i = 0; i--) {
        result[i] = result[i] * suffixProduct;
        suffixProduct *= nums[i];
    }

    return result;
}

时间复杂度分析:

  • 时间复杂度: O(n),其中n是数组的长度。我们迭代数组两次。
  • 空间复杂度: O(1),因为我们使用输出数组来存储中间结果并且不使用任何额外的空间。

基本解决方案的改进:

  • 优化后的解决方案通过使用中间结果的输出数组将空间复杂度降低到 O(1)。

边缘情况和测试:

边缘情况:

  1. 数组包含零。
  2. 数组包含负数。
  3. 数组长度为最小 (2) 或最大 (10^5) 限制。

测试用例:

console.log(productExceptSelf([1,2,3,4])); // [24,12,8,6]
console.log(productExceptSelf([-1,1,0,-3,3])); // [0,0,9,0,0]
console.log(productExceptSelf([2,2,2,2])); // [8,8,8,8]
console.log(productExceptSelf([0,0])); // [0,0]
console.log(productExceptSelf([5])); // This should not be a valid input as the minimum length is 2
console.log(productExceptSelf([1,2])); // [2, 1]

console.log(productExceptSelfOptimized([1,2,3,4])); // [24,12,8,6]
console.log(productExceptSelfOptimized([-1,1,0,-3,3])); // [0,0,9,0,0]
console.log(productExceptSelfOptimized([2,2,2,2])); // [8,8,8,8]
console.log(productExceptSelfOptimized([0,0])); // [0,0]
console.log(productExceptSelfOptimized([5])); // This should not be a valid input as the minimum length is 2
console.log(productExceptSelfOptimized([1,2])); // [2, 1]

一般解决问题的策略:

  1. 理解问题:仔细阅读问题陈述,了解需求和约束。
  2. 识别关键操作:确定需要的关键操作,例如计算前缀和后缀乘积。
  3. 优化可读性:使用清晰简洁的逻辑,确保代码易于理解。
  4. 彻底测试:使用各种情况(包括边缘情况)测试解决方案,以确保正确性。

识别类似问题:

  1. 前缀和数组:

    • 需要计算范围查询的前缀和的问题。
    • 示例:范围求和查询。
  2. 就地算法:

    • 需要在有限的额外空间内进行操作的问题。
    • 示例:将数组向右旋转 k 步。
  3. 数组操作:

    • 需要根据具体情况修改数组的问题。
    • 示例:将零移至数组末尾。

结论:

  • 使用额外空间的基本方法和优化的就地方法可以有效地解决计算除 self 之外的数组的乘积的问题。
  • 理解问题并将其分解为可管理的部分至关重要。
  • 使用清晰的逻辑并优化可读性可确保解决方案易于理解。
  • 使用各种边缘情况进行测试可确保稳健性。
  • 认识问题的模式可以帮助将类似的解决方案应用于其他挑战。

通过练习这些问题和策略,您可以提高解决问题的能力,并为各种编码挑战做好更好的准备。

版本聲明 本文轉載於:https://dev.to/__zamora__/typescript-coding-chronicles-product-of-array-except-self-3gg4?1如有侵犯,請聯絡[email protected]刪除
最新教學 更多>
  • 如何取消註冊 net/http 套件中的處理程序?
    如何取消註冊 net/http 套件中的處理程序?
    在net/http中取消註冊處理程序在net/http中,處理程序可以使用http.Handle動態註冊到特定的URL模式功能。但是,預設的多工器不提供取消註冊處理程序的機制。 取消註冊處理程序的一種方法是建立一個擴充標準 http.ServeMux 類型的自訂多工器。此自訂多工器可以包含用於取消註...
    程式設計 發佈於2024-12-21
  • Go的別名型別轉換會建立副本嗎?
    Go的別名型別轉換會建立副本嗎?
    別名之間賦值會觸發Go中的複製嗎? Go允許使用別名定義自訂類型。人們擔心這些別名類型之間的轉換是否會導致副本或僅導致結構變更。 考慮以下範例:type MyString string var s = "very long string" var ms = MyString(s...
    程式設計 發佈於2024-12-21
  • 如何找到 C++ 向量中的最大值或最小值?
    如何找到 C++ 向量中的最大值或最小值?
    在C 語言中尋找向量中的最大值或最小值從C 語言中的向量取得最大值或最小值是一項常見的程式設計任務。讓我們探討如何實現此目的並解決與 max_element 函數相關的特定錯誤。 使用 max_element 庫中的 max_element 函數傳回一個指向的迭代器到給定範圍內的最大值。若要將其與向...
    程式設計 發佈於2024-12-21
  • 插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入資料時如何修復「常規錯誤:2006 MySQL 伺服器已消失」?
    插入記錄時如何解決「一般錯誤:2006 MySQL 伺服器已消失」介紹:將資料插入MySQL 資料庫有時會導致錯誤「一般錯誤:2006 MySQL 伺服器已消失」。當與伺服器的連線遺失時會出現此錯誤,通常是由於 MySQL 配置中的兩個變數之一所致。 解決方案:解決此錯誤的關鍵是調整wait_tim...
    程式設計 發佈於2024-12-21
  • 如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    如何在 PHP 中組合兩個關聯數組,同時保留唯一 ID 並處理重複名稱?
    在 PHP 中組合關聯數組在 PHP 中,將兩個關聯數組組合成一個數組是常見任務。考慮以下請求:問題描述:提供的代碼定義了兩個關聯數組,$array1 和 $array2。目標是建立一個新陣列 $array3,它合併兩個陣列中的所有鍵值對。 此外,提供的陣列具有唯一的 ID,而名稱可能重疊。要求是建...
    程式設計 發佈於2024-12-21
  • 在 Go 中使用 WebSocket 進行即時通信
    在 Go 中使用 WebSocket 進行即時通信
    构建需要实时更新的应用程序(例如聊天应用程序、实时通知或协作工具)需要比传统 HTTP 更快、更具交互性的通信方法。这就是 WebSockets 发挥作用的地方!今天,我们将探讨如何在 Go 中使用 WebSocket,以便您可以向应用程序添加实时功能。 在这篇文章中,我们将介绍: WebSocke...
    程式設計 發佈於2024-12-21
  • 如何在 C++ 巨集中實作可選參數以進行程式碼自訂?
    如何在 C++ 巨集中實作可選參數以進行程式碼自訂?
    使用 C 巨集自訂參數巨集是 C 程式設計的基本面,允許程式碼自訂和靈活性。一個常見的要求是能夠在巨集中定義可選參數。 可選參數考慮以下範例,其中我們有一個列印字串的巨集: #define PRINT_STRING(message) PrintString(message, 0, 0)此巨集接受一個...
    程式設計 發佈於2024-12-21
  • 大批
    大批
    方法是可以在物件上呼叫的 fns 數組是對象,因此它們在 JS 中也有方法。 slice(begin):將陣列的一部分提取到新數組中,而不改變原始數組。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index ...
    程式設計 發佈於2024-12-21
  • 如何創建 100% 高度並隱藏滾動條的全螢幕 Iframe?
    如何創建 100% 高度並隱藏滾動條的全螢幕 Iframe?
    全螢幕iframe高度為100%查詢:是否普遍支援iframe height=100%跨瀏覽器?當使用XHTML1作為doctype時,高度為100%的iframe是否會佔據頁面剩餘高度(不包括頂部的50px固定高度框架)?另外,如何在自動設定 iframe 高度的同時完全隱藏捲軸? 回應:雖然可以...
    程式設計 發佈於2024-12-21
  • 如何解決 VS2010 中混合 C 和 C++ 專案中的 LNK2001 連結器錯誤?
    如何解決 VS2010 中混合 C 和 C++ 專案中的 LNK2001 連結器錯誤?
    解決VS2010 中混合C 和C 專案中的連結器錯誤問題描述將C 程式碼整合到不同VS2010 專案中的C專案中導致從C 程式碼呼叫C 函數時出現連結錯誤。此錯誤標識為 LNK2001,與未解析的外部符號有關。 解決方案要修正此問題,請遵循特定準則來確保程式碼庫的正確組織: 模組化程式碼: 每個C模...
    程式設計 發佈於2024-12-21
  • 如何在.NET MySqlCommand中啟用MySQL使用者定義變數?
    如何在.NET MySqlCommand中啟用MySQL使用者定義變數?
    在.NET MySqlCommand中使用MySql使用者定義變數在.NET MySqlCommand中執行涉及使用者定義變數的MySQL語句時,您可能會遇到致命錯誤。要解決此問題,請按照下列步驟操作:在您的程式碼中,您有一條 MySQL 語句,用於設定使用者定義的變數“@a”,然後選擇其值。但是,...
    程式設計 發佈於2024-12-21
  • 如何在 Windows 版 XAMPP 升級 PHP:逐步指南
    如何在 Windows 版 XAMPP 升級 PHP:逐步指南
    在XAMPP for Windows 中升級PHP:綜合指南在XAMPP for Windows 中升級PHP 對於維護安全性、功能和效能至關重要您的網頁應用程式的相容性。本指南將提供成功升級 PHP 的逐步流程。 從 PHP 官方網站降級您可能嘗試過直接下載最新的 PHP來自 PHP 官方網站的版...
    程式設計 發佈於2024-12-21
  • 如何可靠地確定我的 PHP 腳本是從命令列運行還是透過 HTTP 運行?
    如何可靠地確定我的 PHP 腳本是從命令列運行還是透過 HTTP 運行?
    確定PHP 中的命令列執行或HTTP 執行PHP 腳本開發中的一個常見任務是確定執行環境的類型,無論是該腳本透過命令列或透過HTTP 運行。這些知識對於制定輸出格式決策和相應地自訂行為至關重要。 檢查 SERVER['argc'] 是否存在的傳統方法並不可靠,因為即使使用“Apach...
    程式設計 發佈於2024-12-21
  • 如何增加 Web 表單的最大 POST 資料大小?
    如何增加 Web 表單的最大 POST 資料大小?
    最大化後期資料處理以增強表單提交在Web 開發中,經常會遇到需要處理大量資料(例如使用者輸入或檔案上傳)的情況。透過表單元素提交。處理大量發布資料對於確保網站的無縫運作至關重要。但是,可能存在限制最大貼文大小的限制,從而導致意外錯誤並阻礙資料提交。 為了應對這項挑戰,必須探索增加 Web 應用程式中...
    程式設計 發佈於2024-12-21
  • 如何在 C++ 中定義靜態 const std::string 成員?
    如何在 C++ 中定義靜態 const std::string 成員?
    定義const std::string 類型的靜態資料成員在C 中,定義std::string 類型的私有靜態const 成員在類別內使用類別內初始化,如下所示,不符合C標準:class A { private: static const string RECTANGLE = &q...
    程式設計 發佈於2024-12-21

免責聲明: 提供的所有資源部分來自互聯網,如果有侵犯您的版權或其他權益,請說明詳細緣由並提供版權或權益證明然後發到郵箱:[email protected] 我們會在第一時間內為您處理。

Copyright© 2022 湘ICP备2022001581号-3