SWIFT
-
Deep copy & Shallow copySwift 2021. 5. 25. 17:47
์๋ ํ์ธ์. ๊ทธ๋ฆฐ์ ๋๋ค๐ข ์ด๋ฒ ํฌ์คํ ์์๋ Deep copy(๊น์ ๋ณต์ฌ)์ Shallow copy(์์ ๋ณต์ฌ)์ ๋ํด ํ์ตํด๋ณด๊ฒ ์ต๋๋ค๐ง๐ป๐ป ๋ณธ๊ฒฉ์ ์ผ๋ก ์์๋ณด๊ธฐ์ ! ๊ธฐ๋ณธ์ ์ผ๋ก ๋ชจ๋ ๋ฐ์ดํฐ ํ์ ์ ๊ฐ ํน์ ์ฐธ์กฐ ํ์ ์ ๊ฐ์ง๋๊ฑด ์๊ณ ๊ณ์์ฃ ? ๊ฐ๋จํ ๋ ํ์ ์ ๋ํด ์ค๋ช ํด๋ณด์๋ฉด, ๊ฐ ํ์ ์ผ๋ก ์์ฑ๋ ๋ฐ์ดํฐ๋ ๊ฐ๊ฐ ํด๋นํ๋ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๋ฐ๋ก ์์ ํฉ๋๋ค. ์ฐธ์กฐ ํ์ ์ผ๋ก ์์ฑ๋ ์ธ์คํด์ค๋ ์ฃผ์๋ฅผ ๊ณต์ ํ์ฌ ๊ฐ์ ์ฃผ์๋ฅผ ์ฐธ์กฐํ ๊ฐ์ด ๋ฐ๋๋ฉด ๊ฐ์ด ๋ณ๊ฒฝ๋ฉ๋๋ค. ์ด ๋ ์ฐจ์ด๋ฅผ ํตํด ๊น์ ๋ณต์ฌ์ ์์ ๋ณต์ฌ์ ๋ํด ์ด๋จ๋ ์ผ์ด๋๊ณ ์ด๋ป๊ฒ ์ฌ์ฉํ ์ง ์์๋ด ์๋ค๐๐ป Deep copy : ๊น์ ๋ณต์ฌ๋ก ๋ฐ์ดํฐ๋ฅผ ๊ทธ๋๋ก ๋ณต์ฌํ์ฌ ๋ณต์ฌ๋ ๋ ๋ฐ์ดํฐ ๊ฐ์ฒด๋ ๊ฐ๊ฐ์ ๋ฉ๋ชจ๋ฆฌ๋ฅผ ๊ฐ์ง๋๋ค. : ์ฃผ๋ก ๊ธฐ๋ณธ์ ์ผ๋ก ๊ฐ ํ์ ์ ๊ฐ์ฒด๋ค์ ์์ฑํ๋ฉด ๊น์ ๋ณต์ฌ๋ก..
-
์คํจ์จAlgorithm 2021. 5. 24. 10:58
์๋ ๋ฌธ์ ๋ ํ๋ก๊ทธ๋๋จธ์ค์์ ์ ๊ณตํ๋ 2019 KAKAO BLIND RECRUITMENT > ์คํจ์จ์ ๋ฌธ์ ์ ๋๋ค๐ง๐ป๐ป ๋ฌธ์ ์ ์ ์ํผ ๊ฒ์ ๊ฐ๋ฐ์ ์ค๋ ๋ฆฌ๋ ํฐ ๊ณ ๋ฏผ์ ๋น ์ก๋ค. ๊ทธ๋ ๊ฐ ๋ง๋ ํ๋์ฆ ์ค์ฒ์ฑ์ด ๋์ฑ๊ณต์ ๊ฑฐ๋์ง๋ง, ์์ฆ ์ ๊ท ์ฌ์ฉ์์ ์๊ฐ ๊ธ๊ฐํ ๊ฒ์ด๋ค. ์์ธ์ ์ ๊ท ์ฌ์ฉ์์ ๊ธฐ์กด ์ฌ์ฉ์ ์ฌ์ด์ ์คํ ์ด์ง ์ฐจ์ด๊ฐ ๋๋ฌด ํฐ ๊ฒ์ด ๋ฌธ์ ์๋ค. ์ด ๋ฌธ์ ๋ฅผ ์ด๋ป๊ฒ ํ ๊น ๊ณ ๋ฏผ ํ ๊ทธ๋ ๋ ๋์ ์ผ๋ก ๊ฒ์ ์๊ฐ์ ๋๋ ค์ ๋์ด๋๋ฅผ ์กฐ์ ํ๊ธฐ๋ก ํ๋ค. ์ญ์ ์ํผ ๊ฐ๋ฐ์๋ผ ๋๋ถ๋ถ์ ๋ก์ง์ ์ฝ๊ฒ ๊ตฌํํ์ง๋ง, ์คํจ์จ์ ๊ตฌํ๋ ๋ถ๋ถ์์ ์๊ธฐ์ ๋น ์ง๊ณ ๋ง์๋ค. ์ค๋ ๋ฆฌ๋ฅผ ์ํด ์คํจ์จ์ ๊ตฌํ๋ ์ฝ๋๋ฅผ ์์ฑํ๋ผ. ์คํจ์จ์ ๋ค์๊ณผ ๊ฐ์ด ์ ์ํ๋ค. ์คํ ์ด์ง์ ๋๋ฌํ์ผ๋ ์์ง ํด๋ฆฌ์ดํ์ง ๋ชปํ ํ๋ ์ด์ด์ ์ / ์คํ ์ด์ง์ ๋๋ฌํ ํ๋ ์ด์ด..
-
์ง์ง์ด ์ ๊ฑฐํ๊ธฐAlgorithm 2021. 5. 21. 10:27
์๋ ๋ฌธ์ ๋ ํ๋ก๊ทธ๋๋จธ์ค์์ ์ ๊ณตํ๋ 2017 ํ์ค๋ค์ด > ์ง์ง์ด ์ ๊ฑฐํ๊ธฐ์ ๋ฌธ์ ์ ๋๋ค๐ง๐ป๐ป ๋ฌธ์ ์ ์ ์ง์ง์ด ์ ๊ฑฐํ๊ธฐ๋, ์ํ๋ฒณ ์๋ฌธ์๋ก ์ด๋ฃจ์ด์ง ๋ฌธ์์ด์ ๊ฐ์ง๊ณ ์์ํฉ๋๋ค. ๋จผ์ ๋ฌธ์์ด์์ ๊ฐ์ ์ํ๋ฒณ์ด 2๊ฐ ๋ถ์ด ์๋ ์ง์ ์ฐพ์ต๋๋ค. ๊ทธ๋ค์, ๊ทธ ๋์ ์ ๊ฑฐํ ๋ค, ์๋ค๋ก ๋ฌธ์์ด์ ์ด์ด ๋ถ์ ๋๋ค. ์ด ๊ณผ์ ์ ๋ฐ๋ณตํด์ ๋ฌธ์์ด์ ๋ชจ๋ ์ ๊ฑฐํ๋ค๋ฉด ์ง์ง์ด ์ ๊ฑฐํ๊ธฐ๊ฐ ์ข ๋ฃ๋ฉ๋๋ค. ๋ฌธ์์ด S๊ฐ ์ฃผ์ด์ก์ ๋, ์ง์ง์ด ์ ๊ฑฐํ๊ธฐ๋ฅผ ์ฑ๊ณต์ ์ผ๋ก ์ํํ ์ ์๋์ง ๋ฐํํ๋ ํจ์๋ฅผ ์์ฑํด ์ฃผ์ธ์. ์ฑ๊ณต์ ์ผ๋ก ์ํํ ์ ์์ผ๋ฉด 1์, ์๋ ๊ฒฝ์ฐ 0์ ๋ฆฌํดํด์ฃผ๋ฉด ๋ฉ๋๋ค. ์๋ฅผ ๋ค์ด, ๋ฌธ์์ด S = baabaa ๋ผ๋ฉด b aa baa → bb aa → aa → ์ ์์๋ก ๋ฌธ์์ด์ ๋ชจ๋ ์ ๊ฑฐํ ์ ์์ผ๋ฏ๋ก 1์ ๋ฐํํฉ๋๋ค. ์ ํ์ฌ..
-
์ฐ๊ฒฐ ๋ฆฌ์คํธCS(ComputerScience) 2021. 5. 20. 12:02
์๋ ํ์ธ์. ๊ทธ๋ฆฐ์ ๋๋ค๐ข ์ด๋ฒ ํฌ์คํ ์์๋ ์ฐ๊ฒฐ ๋ฆฌ์คํธ์ ๋ํด ์์๋ณด๊ณ Swift๋ก ๊ตฌํํด๋ณด๊ฒ ์ต๋๋ค๐ง๐ป๐ป ์ฐ๊ฒฐ๋ฆฌ์คํธ : ์ด์ / ๋ค์์ ์ฌ ๊ฐ์ ์ฐธ์กฐ ์ ๋ณด ๊ฐ์ง๋ ๋ฐฐ์ด์ ํํ - ๋ฌผ๋ฆฌ์ ์์๊ฐ ์์ฐจ์ ์ด์ง ์์ - ํ๋ฒ์ ์ฐพ๋ ๋ฐ์ดํฐ์ ์ ๊ทผ ๋ถ๊ฐ - ๋ฐ์ดํฐ ์ฝ์ ๋ฐ ์ญ์ ์ ์ด๋ ์์ด ์ฐธ์กฐ ๊ฐ ๋ณ๊ฒฝ๋ง ํด์ฃผ๋ฉด๋์ ๋ฐฐ์ด๋ณด๋ค ์ฌ์ (์๋๊ฐ ๋น ๋ฆ) - ๋ ธ๋์ ๋ฐ์ดํฐ๋ก ๊ตฌ์ฑ - ๋ ธ๋์๋ ๋ค์ ์ฃผ์๋ฅผ ๋ํ๋ด๋ ํฌ์ธํฐ๋ฅผ ์ง๋ - ๊ฒ์ ์๋๊ฐ ๋๋ฆฌ๊ณ ์ ์ฅ ๊ณต๊ฐ ํจ์จ์ฑ์ด ๋จ์ด์ง Swift๋ก ๋จ๋ฐฉํฅ ์ฐ๊ฒฐ ๋ฆฌ์คํธ ๊ตฌํํ๊ธฐ import Foundation // ๋ ธ๋ ์ ์, Node์ ๊ฐ์ธ value์ ๋ค์ ๋ ธ๋์ ์ฃผ์๋ฅผ ๊ฐ์ง next class Node { var data: T? var next: Node? init(data..
-
ํผ๋ณด๋์น ์Algorithm 2021. 5. 20. 11:01
์๋ ๋ฌธ์ ๋ ํ๋ก๊ทธ๋๋จธ์ค์์ ์ ๊ณตํ๋ ํผ๋ณด๋์น ์์ ๋ฌธ์ ์ ๋๋ค๐ง๐ป๐ป ๋ฌธ์ ์ ์ ํผ๋ณด๋์น ์๋ F(0) = 0, F(1) = 1์ผ ๋, 1 ์ด์์ n์ ๋ํ์ฌ F(n) = F(n-1) + F(n-2) ๊ฐ ์ ์ฉ๋๋ ์ ์ ๋๋ค. F(2) = F(0) + F(1) = 0 + 1 = 1 F(3) = F(1) + F(2) = 1 + 1 = 2 F(4) = F(2) + F(3) = 1 + 2 = 3 F(5) = F(3) + F(4) = 2 + 3 = 5 ์ ๊ฐ์ด ์ด์ด์ง๋๋ค. 2 ์ด์์ n์ด ์ ๋ ฅ๋์์ ๋, n๋ฒ์งธ ํผ๋ณด๋์น ์๋ฅผ 1234567์ผ๋ก ๋๋ ๋๋จธ์ง๋ฅผ ๋ฆฌํดํ๋ ํจ์, solution์ ์์ฑํด ์ฃผ์ธ์. ์ ํ ์ฌํญ * n์ 1์ด์, 100000์ดํ์ธ ์์ฐ์์ ๋๋ค. ์ ์ถ๋ ฅ ์ 3 2 5 5 ํผ๋ณด๋์น์๋ 0๋ฒ์งธ๋ถํฐ..
-
ํจํด (์๋ณ์, ๊ฐ ๋ฐ์ธ๋ฉ, ํํ)Swift 2021. 5. 19. 16:35
์๋ ํ์ธ์. ๊ทธ๋ฆฐ์ ๋๋ค๐ข ์ด๋ฒ ํฌ์คํ ์์ ์ ๋ฒ ์์ผ๋ ํจํด์ ์ด์ด ๊ฐ์ ์ถ์ถํ๊ฑฐ๋ ๋ฌด์ํ๋ ํจํด์ ๋๋จธ์ง 3๊ฐ์ ๋ํด ์์๋ณด๊ฒ ์ต๋๋ค๐ง๐ป๐ป ์๋ณ์ ํจํด (Identifier Pattern) : ๋ณ,์์์ ๋ค์ด๋ฐ์ ํด๋นํ๋ ๊ฐ์ ๋งค์นญ์ํค๋ ํจํด let name: String = "GREEN" ๋ค์์ด๋ผ๋ ์์๊ฐ ๊ทธ๋ฆฐ์ด๋ผ๋ ๋ฌธ์์ด ๊ฐ์ ์๋ณ์๊ฐ ๋ฉ๋๋ค. ๋์ ๋ฐ๋ผ ์๋ณ์ ํจํด์ด ๊ฐ ๋ฐ์ธ๋ฉ ํจํด์ ํ ์ข ๋ฅ๊ฐ ๋๊ธฐ๋ ํฉ๋๋ค. ๊ฐ ๋ฐ์ธ๋ฉ ํจํด (Value-Binding Pattern) : ๋ณ,์์์ ๋ค์ด๋ฐ์ ๋งค์นญ๋ ๊ฐ ๋ฐ์ธ๋ฉ let person = ("GREEN", 10) switch person { case let (name, age): print("\(name), \(age)") } switch person {..
-
ํ (Queue)CS(ComputerScience) 2021. 5. 19. 14:26
์๋ ํ์ญ๋๊น. ๊ทธ๋ฆฐ์ ๋๋ค๐ข ์ด๋ฒ ํฌ์คํ ์์๋ ์คํ๊ณผ ๋ฐ๋๋๋ ํ์ ๋ํด ์์๋ณด๊ฒ ์ต๋๋ค๐ง๐ป๐ป ํ(Queue) : FIFO(์ ์ ์ ์ถ) ๋ฐฉ์์ ์๋ฃ๊ตฌ์กฐ๋ก ์ฝ๊ฒ ์๊ฐํ๋ฉด ๋๊ธฐ์ด์ ์์์ ๋ง์ด ํ์ฉ๋ฉ๋๋ค. -> ์ค์ํํธ์์๋ ํ ์๋ฃ๊ตฌ์กฐ๊ฐ ๋ฐ๋ก ์๊ธฐ์ ์ง์ ๋ง๋ค์ด์ ๊ตฌํํด์ผ ํฉ๋๋ค. ํ๋ฅผ ๊ตฌํํ๊ธฐ ์ํ 4๊ฐ์ง ๋ฐฉ๋ฒ 1) ๋ฐฐ์ด 1๊ฐ๋ฅผ ์ฌ์ฉํ ํ ๊ตฌํ : ํ์ ๋ฐ์ดํฐ๋ฅผ ์ถ๊ฐ ์ O(1)์ ์๊ฐ๋ณต์ก๋๋ฅผ ๊ฐ์ ธ ํธ๋ฆฌํ์ง๋ง ๋์ ํ์์ ๋ฐ์ดํฐ๋ฅผ ์ถ์ถ ์ ์ด์ ๋ฐ์ดํฐ๋ค์ ์ ๋ถ ์์น๋ฅผ ์ด๋์ํด์ผ๋ก O(n) ์๊ฐ๋ณต์ก๋๋ฅผ ๊ฐ์ง๋๋ค. ๋นํจ์จ์ ์ ๋๋ค. 2) ์ฐ๊ฒฐ ๋ฆฌ์คํธ๋ฅผ ์ฌ์ฉํ ํ ๊ตฌํ 3) ๋ฐฐ์ด 2๊ฐ๋ฅผ ์ฌ์ฉํ ํ ๊ตฌํ : ์ถ๊ฐ๋๋ ํ์ ์ญ์ ๋ ํ(๋ฐ๋ ํ)์ ๋ฐฐ์ด 2๊ฐ๋ฅผ ์์ฑํ์ฌ ๊ธฐ๋ฅ์ ์์ผ์ค๋๋ค. ๊ทธ๋ด๊ฒฝ์ฐ ํ๊ณผ ํธ์ ๋ชจ๋ O(1..
-
๋ด์ Algorithm 2021. 5. 19. 13:35
์๋ ๋ฌธ์ ๋ ํ๋ก๊ทธ๋๋จธ์ค์์ ์ ๊ณตํ๋ ์๊ฐ ์ฝ๋ ์ฑ๋ฆฐ์ง ์์ฆ1 > ๋ด์ ์ ๋ฌธ์ ์ ๋๋ค๐ง๐ป๐ป ๋ฌธ์ ์ ์ ๊ธธ์ด๊ฐ ๊ฐ์ ๋ 1์ฐจ์ ์ ์ ๋ฐฐ์ด a, b๊ฐ ๋งค๊ฐ๋ณ์๋ก ์ฃผ์ด์ง๋๋ค. a์ b์ ๋ด์ ์ return ํ๋๋ก solution ํจ์๋ฅผ ์์ฑํด์ฃผ์ธ์.์ ํ์ฌํญ a, b์ ๊ธธ์ด๋ 1 ์ด์ 1,000 ์ดํ์ ๋๋ค. a, b์ ๋ชจ๋ ์๋ -1,000 ์ด์ 1,000 ์ดํ์ ๋๋ค. ์ ์ถ๋ ฅ ์ [1,2,3,4] [-3,-1,0,2] 3 [-1,0,1] [1,0,-1] -2 ์ ์ถ๋ ฅ ์ ์ค๋ช ์ ์ถ๋ ฅ ์ #1 a์ b์ ๋ด์ ์ 1*(-3) + 2*(-1) + 3*0 + 4*2 = 3 ์ ๋๋ค. ์ ์ถ๋ ฅ ์ #2 a์ b์ ๋ด์ ์ (-1)*1 + 0*0 + 1*(-1) = -2 ์ ๋๋ค. ์ด๋, a์ b์ ๋ด์ ์ a[0]*b[0] + a[..