From 771c1395f1d5822cde3a8224f3a8f0670c5e3048 Mon Sep 17 00:00:00 2001 From: SSOOYA Date: Thu, 19 Oct 2023 14:02:30 +0900 Subject: [PATCH] =?UTF-8?q?unsolve/#171:=20=ED=94=84=EB=A1=9C=EA=B7=B8?= =?UTF-8?q?=EB=9E=98=EB=A8=B8=EC=8A=A4=20=EC=88=9C=EC=9C=84=20-=20timeout?= MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit --- AlgorithmReview.xcodeproj/project.pbxproj | 4 +++ .../Lv3/\354\210\234\354\234\204.swift" | 35 +++++++++++++++++++ 2 files changed, 39 insertions(+) create mode 100644 "AlgorithmReview/Programmers/Lv3/\354\210\234\354\234\204.swift" diff --git a/AlgorithmReview.xcodeproj/project.pbxproj b/AlgorithmReview.xcodeproj/project.pbxproj index dd8a4a5..b252c3d 100644 --- a/AlgorithmReview.xcodeproj/project.pbxproj +++ b/AlgorithmReview.xcodeproj/project.pbxproj @@ -22,6 +22,7 @@ EE5CEEC62A39A6BB00E1907E /* 가장 큰 정사각형 찾기.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE5CEEC52A39A6BB00E1907E /* 가장 큰 정사각형 찾기.swift */; }; EE6AEAA529AF24F000AB6E16 /* 명예의 전당.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE6AEAA429AF24F000AB6E16 /* 명예의 전당.swift */; }; EE80682A2A19CE2700290DE9 /* 여행 경로.swift in Sources */ = {isa = PBXBuildFile; fileRef = EE8068292A19CE2700290DE9 /* 여행 경로.swift */; }; + EEA92E002AE0EE9500C63ED6 /* 순위.swift in Sources */ = {isa = PBXBuildFile; fileRef = EEA92DFF2AE0EE9500C63ED6 /* 순위.swift */; }; EEAEC89F298CACDD001B1D62 /* main.swift in Sources */ = {isa = PBXBuildFile; fileRef = EEAEC89E298CACDD001B1D62 /* main.swift */; }; EEBC48342AD9343C000BBAF1 /* 셔틀버스.swift in Sources */ = {isa = PBXBuildFile; fileRef = EEBC48332AD9343C000BBAF1 /* 셔틀버스.swift */; }; EEC10A8A2A9EE99900882987 /* 입국 심사.swift in Sources */ = {isa = PBXBuildFile; fileRef = EEC10A892A9EE99900882987 /* 입국 심사.swift */; }; @@ -154,6 +155,7 @@ EE938DA629CE9DCF003A5BF6 /* 점프와 순간 이동.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "점프와 순간 이동.swift"; sourceTree = ""; }; EE9C082C2AA1935000CA7DC7 /* 가장 긴 팰린드롬.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "가장 긴 팰린드롬.swift"; sourceTree = ""; }; EE9D44B22A1B22E900D34A37 /* 프렌즈4블록.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "프렌즈4블록.swift"; sourceTree = ""; }; + EEA92DFF2AE0EE9500C63ED6 /* 순위.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "순위.swift"; sourceTree = ""; }; EEA997F629A6208E0063F86B /* 가장 가까운 같은 글자.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "가장 가까운 같은 글자.swift"; sourceTree = ""; }; EEA997F829A6387F0063F86B /* 소수 찾기.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = "소수 찾기.swift"; sourceTree = ""; }; EEA997FA29A63D7E0063F86B /* 2228.swift */ = {isa = PBXFileReference; lastKnownFileType = sourcecode.swift; path = 2228.swift; sourceTree = ""; }; @@ -458,6 +460,7 @@ EECBCFED2ADCFEB90056BC96 /* 연속 펄스 부분 수열의 합.swift */, EECBCFEF2ADE55970056BC96 /* 풍선 터뜨리기.swift */, EE123C1C2ADFAAFB00832264 /* 다단계 칫솔 판매.swift */, + EEA92DFF2AE0EE9500C63ED6 /* 순위.swift */, ); path = Lv3; sourceTree = ""; @@ -538,6 +541,7 @@ EE80682A2A19CE2700290DE9 /* 여행 경로.swift in Sources */, EE123C1D2ADFAAFB00832264 /* 다단계 칫솔 판매.swift in Sources */, EEC5CAF129B0677900FF4C26 /* 로또의 최고 순위와 최저 순위.swift in Sources */, + EEA92E002AE0EE9500C63ED6 /* 순위.swift in Sources */, EEBC48342AD9343C000BBAF1 /* 셔틀버스.swift in Sources */, EEEA901E2A8B24A800EBE008 /* 행렬 테두리 회전하기.swift in Sources */, EE27C54329C7E6EB00285CC5 /* 15686.swift in Sources */, diff --git "a/AlgorithmReview/Programmers/Lv3/\354\210\234\354\234\204.swift" "b/AlgorithmReview/Programmers/Lv3/\354\210\234\354\234\204.swift" new file mode 100644 index 0000000..54692c7 --- /dev/null +++ "b/AlgorithmReview/Programmers/Lv3/\354\210\234\354\234\204.swift" @@ -0,0 +1,35 @@ +// +// 순위.swift +// AlgorithmReview +// +// Created by 박소윤 on 2023/10/19. +// + +import Foundation + +func timeout(_ n:Int, _ results:[[Int]]) -> Int { + + func forGrade(_ nodes: [Int]) { + let canGrade = nodes.count + lose[nodes.last!].count == n + for i in lose[nodes.last!] { + forGrade(nodes + [i]) + } + if canGrade { + ans = max(ans, nodes.count) + } + } + + var lose = [[Int]](repeating: [], count: n) + var canStart = [Bool](repeating: true, count: n) + for i in results { + lose[i[1]-1].append(i[0]-1) + canStart[i[0]-1] = false + } + + var ans = 0 + let startIdx = canStart.firstIndex(of: true) + if startIdx != nil { + forGrade([startIdx!]) + } + return ans +}