Product of Array Except Self

2025. 1. 5. 14:40·PS/LeetCode
반응형

문제

https://leetcode.com/problems/product-of-array-except-self/description/

입력

2 <= nums.length <= 10^5
-30 <= nums[i] <= 30

결과

ans: [Int] = 자신을 제외한 곱 배열

해석

첫 반복문에서 모든 값을 순회하며 0 개수를 count와 동시에 0을 제외환 모든 곱의 결과를 계산

 

실질적인 계산일 때 2가지 분기로 구분

 

1) 현재 값이 0일 때

- 다른 0이 존재하면 무조건 0, 그렇지 않으면 total

 

2) 현재 값이 0이 아닐 때

- 0이 한번이라도 존재하면 0, 아니면 total / 현재 값  

코드

class Solution {
    func productExceptSelf(_ nums: [Int]) -> [Int] {
        var zeroCount: Int = 0
        let total = nums.reduce(1) { prev, now in
            if now == 0 {
                zeroCount += 1
                return prev 
            } else {
                return prev * now 
            }
        }

        var ans: [Int] = []

        for num in nums {
            var product = 0
            if num == 0 {
                product = zeroCount == 1 ? total : 0
            } else {
                product = zeroCount == 0 ? total/num : 0
            }
            ans.append(product)
        }
        return ans
    }
}

 

반응형

'PS > LeetCode' 카테고리의 다른 글

Maximum Product Subarray  (0) 2025.01.08
Maximum Subarray  (1) 2025.01.05
Best Time to Buy and Sell Stock  (0) 2025.01.05
Two Sum  (0) 2025.01.05
[LeetCode] 3. Longest Substring Without Repeating Characters  (0) 2024.10.24
'PS/LeetCode' 카테고리의 다른 글
  • Maximum Product Subarray
  • Maximum Subarray
  • Best Time to Buy and Sell Stock
  • Two Sum
Hamp
Hamp
남들에게 보여주기 부끄러운 잡다한 글을 적어 나가는 자칭 기술 블로그입니다.
  • Hamp
    Hamp의 분리수거함
    Hamp
  • 전체
    오늘
    어제
    • 분류 전체보기 (329) N
      • CS (30)
        • 객체지향 (2)
        • Network (7)
        • OS (6)
        • 자료구조 (1)
        • LiveStreaming (3)
        • 이미지 (1)
        • 잡다한 질문 정리 (0)
        • Hardware (2)
        • 이론 (6)
        • 컴퓨터 그래픽스 (0)
      • Firebase (3)
      • Programing Langauge (41)
        • swift (34)
        • python (6)
        • Kotlin (1)
      • iOS (134)
        • UIKit (37)
        • Combine (1)
        • SwiftUI (34)
        • Framework (7)
        • Swift Concurrency (22)
        • Tuist (6)
        • Setting (11)
        • Modularization (1)
        • Instruments (6)
      • PS (59)
        • 프로그래머스 (24)
        • 백준 (13)
        • LeetCode (19)
        • 알고리즘 (3)
      • Git (18)
        • 명령어 (4)
        • 이론 (2)
        • hooks (1)
        • config (2)
        • action (7)
      • Shell Script (2)
      • Linux (6)
        • 명령어 (5)
      • Spring (21)
        • 어노테이션 (6)
        • 튜토리얼 (14)
      • CI-CD (4)
      • Android (0)
        • Jetpack Compose (0)
      • AI (11) N
        • 이론 (10) N
        • MCP (1)
        • LangGraph (0)
  • 블로그 메뉴

    • 홈
    • 태그
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    Tuist
    property
    프로그래머스
    protocol
    boostcamp
    SwiftUI
    백준
    AVFoundation
    IOS
    dfs
    CS
    concurrency
    dispatch
    UIKit
    lifecycle
    투포인터
    dp
    Swift
    GIT
    Spring
  • 최근 댓글

  • 최근 글

  • 반응형
  • hELLO· Designed By정상우.v4.10.0
Hamp
Product of Array Except Self
상단으로

티스토리툴바