반응형

전체 글 79

<Map> 함수 더하기 추론<조금>, <compactMap>, <flatMap>

안녕하세요. KataRN입니다. 오늘은 함수 Map에 대해 정리해보려고합니다. 제가 프로그래머스 1단계를 쭉 풀면서 다른사람들이 푼 내용과 비교도 해봤는데 map, reduce, filter 이 3가지를 쓴 풀이들이 코드가 깔끔합니다. 그리고 추론을 하면 할 수록 코드는 더 간결해지죠.(단 상대적으로 효율성은 떨어지더라구요...) 문제는 코드가 간결한 만큼 읽는 순간 이해가 빠르게 되느냐인데 제가 추론에 약해서인지 처음엔 힘들었습니다. 그래서 이번 기회에 3가지 함수에 대해 정리를 하고 응용도 해보겠습니다. 우선 공식문서를 통해 알아보도록 하죠. map(_:) Returns an array containing the results of mapping the given closure over the seq..

<components>, <split> (글자 자르기)

안녕하세요 KataRN입니다. 오늘은 String을 자르는 방법들에 대해 알아보려합니다. 우선 크게 2가지가 있습니다.(알아본게 2개라는뜻입니다. 더있을지도...) 1. components(separatedBy:) Returns an array containing substrings from the receiver that have been divided by a given separator. func components(separatedBy separator: String) -> [String] 흠 string을 넣으면 배열안에 string을 넣어서 돌려받게 생겼네요?예제로 확인해보겠습니다. var str = "Hello, My name is Pane, Go to Hell" var slice = str..

<replacingOccurrences> (문자 변환)

안녕하세요. KataRN입니다. 오늘은 replacingOccurrences 함수에 대해 알아보겠습니다. 이 함수는 글자에서 글자를 찾아 글자를 바꾸는 함수입니다. 응? 가독성 이런식으로 할꺼야? (죄송합니다..) 문자열 치환, 변경 수정 변환 등.. 암튼 글자를 바꾸는겁니다. 우선 오늘도 apple 공식 문서를 먼저 확인하겠습니다. replacingOccurrences(of:with:) Returns a new string in which all occurrences of a target string in the receiver are replaced by another given string. func replacingOccurrences(of target: String, with replacemen..

<enumarated> 함수

안녕하세요. KataRN입니다. 저번시간에 배운 zip함수 기억하십니까? Array와 관련된 함수 중 하나인데 zip함수에서 내용이 너무 없던것 같아서 보충수업 들어갑니다. 오늘 배울 함수는 enumarated 함수 입니다. enumarated란? 번역하면 '열거' 입니다. enumerated() Returns a sequence of pairs (n, x), where n represents a consecutive integer starting at zero and x represents an element of the sequence. func enumerated() -> EnumeratedSequence 애플 문서에 의하면 이렇답니다..ㅎㅎ.. 바로 예제 들어갑니다. let testString =..

<zip> 함수

안녕하세요, KataRN입니다. 오늘은 zip에 대해 알아보겠습니다. 오늘도 열심히 알고리즘을 풀고있는데 배열 2개를 어떻게 요리를 못할까 하다가 알게된 함수입니다. func zip(_ sequence1: Sequence1, _ sequence2: Sequence2) -> Zip2Sequence where Sequence1 : Sequence, Sequence2 : Sequence 보시는 바와 같이 zip를 사용하기 위해서는 2개의 배열이 필요합니다.(많아도 적어도 안됩니다.) 예제로 설명 드리겠습니다. let aArr = [1,2,3,4,5] let bArr = ["a","b","c","d","e"] let zipArr = zip(aArr,bArr) print(zipArr) 위 처럼 print를 하였더..

소수 구하기

안녕하세요. KataRN입니다. 코테 문제를 풀다보면 소수를 구하는 문제가 많습니다. 보통 소수관련 문제가 나오면 효율성도 좋아야 되더라구요... 그리고 소수와 효율성하면 꼭 언급하는 이론이 있습니다. 그건 바로 '에라토스테네스의 체' 입니다. 소수를 하나하나 구하는것보다 아래의 그림처럼 소수의 배수를 제거하는것이 빠릅니다. 이를 포함하여 소수판별코드, 소수의개수, 소수구하기 등을 코드로 구현해봤습니다. 소수 판별 코드(swift) func isPrime(_ num: Int) -> Bool { if num == 0 { return false } if num < 4 { return num == 1 ? false : true } for i in 2...Int(sqrt(Double(num))) { if num..

최대공약수, 최소공배수 구하기

안녕하세요. KataRN입니다. 오늘은 최대공약수와 최소 공배수에 대해 알아보겠습니다. 최대공약수와 최소공배수에 대한 문제를 풀기 위해 코드를 작성했으나 전부 시간초과가 났습니다. 이건 답은 같아도 비효율적이기 때문입니다. 그래서 제가 내린 결론은 무조건 '유클리드 호제법을 이용하여 만들어야한다' 입니다. 유클리드 호제법이란? 유클리드 호제법은 2개의 자연수 또는 정식의 최대공약수를 구하는 알고리즘의 하나이다. 호제법이란 말은 두 수가 서로 상대방 수를 나누어서 결국 원하는 수를 얻는 알고리즘을 나타낸다. 최대공약수, 최소공배수 코드(swift) //최대공약수 func gcd(_ a: Int, _ b: Int) -> Int { if b == 0 { return a } else { return gcd(b,..

코딩테스트

안녕하세요 Kata입니다. 오늘부터 코딩테스트를 꾸준히 공부하려고 합니다. 저는 시간이 부족한게 가장 큰 단점입니다. 코테는 하루아침에 되는건 아닌것같아서 매일 3문제이상을 풀려고합니다.(난이도에 따라 다를수 있음..) 코테에 필요한 기술적인 내용만 작성할것입니다... 풀이는 없습니다... 목표는 아래와 같습니다. - 우선 툭치면 툭하고 나오도록 언어에 익숙해지자. - 같은 문제도 다양한 방법으로 풀 수 있도록 하자. 이상...

안녕하세요.

안녕하세요. Kata입니다. 저는 비전공자이며 학원(웹) 6개월을 다녔습니다. 나이도 적지 않습니다. IOS가 더 재밌어서 학원과정과는 별개로 IOS 공부를 따로 했습니다. 그리고 현재 IOS앱개발 1년차입니다. 앞으로 알게 될, 알게 된, 알고 싶은 내용을 적어볼 예정입니다. 일단 대충이라도 적어놓고 수정해서 고쳐나가는 식으로 해보려합니다. 처음 보신 글의 내용이 재방문시 다르게 바뀌어있더라도 당황하지 말아주세요. 감사합니다.

공지사항 2021.04.02
반응형