programmers 91

[Kotlin] Programmers Lv. 1 자릿수 더하기

https://school.programmers.co.kr/learn/courses/30/lessons/12931 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr Code class Solution { fun solution(n: Int): Int = n.toString().sumOf { it.digitToInt() } } 각 자리수를 더하면 된다. 물론 전통적인 방법인 10으로 나눈 나머지를 sum에 더하고 10으로 나누는 그런 방법을 써도 되지만 귀찮았다. 하나씩 적는것보다 저게 더 간단하니까... sumOf라는 함수를 사용하기 위해 n을 String으..

Programmers/Lv. 1 2023.08.11

[Kotlin] Programmers Lv. 1 자연수 뒤집어 배열로 만들기

https://school.programmers.co.kr/learn/courses/30/lessons/12932 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr Code class Solution { fun solution(n: Long): IntArray = n.toString() .reversed() .map { it.digitToInt() }.toIntArray() } 처음에는 입력받은 값을 각각 분리해야한다 라는 생각이 너무 커서 split을 썼었다. split("")을 쓰니까 ""값이 두개가 생겼고, 이를 없애기 위해 filter{it!=""}을..

Programmers/Lv. 1 2023.08.09

[Kotlin] Programmers Lv. 1 평균 구하기

https://school.programmers.co.kr/learn/courses/30/lessons/12944 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr Code class Solution { //fun solution(arr: IntArray): Double = arr.sum()/arr.size.toDouble() fun solution(arr: IntArray): Double = arr.average() } 당연히 평균이라고 해서 합을 구하고, 갯수로 나누는 그런 방식을 생각했다. 그래서 sum()과 size를 사용해서 결과를 만들었다. 그런데..

Programmers/Lv. 1 2023.08.08

[Kotlin] Programmers Lv. 1 짝수와 홀수

https://school.programmers.co.kr/learn/courses/30/lessons/12937 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr Code class Solution { fun solution(num: Int): String = if( num % 2 == 0 ) "Even" else "Odd" } 짝 홀 구하는거 정도야 뭐.... 2로 나누고 나머지 확인하면 된다. 이게 왜 Lv. 1....? Lv. 0인거 같은데...

Programmers/Lv. 1 2023.08.07

[Kotlin] Programmers Lv. 1 약수의 합

https://school.programmers.co.kr/learn/courses/30/lessons/12928 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr Code class Solution { //fun solution(n: Int): Int = (1 .. n).filter { n % it == 0 }.sum() fun solution(n: Int): Int{ var set = hashSetOf() for (i in 1 .. sqrt(n.toDouble()).toInt()){ if (n % i == 0) { set.add(i) set.add(n /..

Programmers/Lv. 1 2023.08.06

[Kotlin] Programmers 코딩 기초 트레이닝 CLEAR

드디어 programmers Lv.0 문제를 전부 다 풀었다. 생각하지도 못한 부분에서 문제를 많이 발견할 수 있었다. 쉬운 문제라고 얕보다가 큰코다친 경우가 많았다. 코틀린 문법을 잘 안다고 생각했는데 생각보다 내가 모르는 부분이 많았다. 이 기회에 복습한거 같은 느낌. 이제 Lv.0을 다 풀었으니까 Lv.1을 풀어보려고 한다. 근데 그 전에 백준 좀만 더 풀고... 깃허브에 내 랭크를 올려뒀는데 너무 부끄럽다. 보여주기식이라도 백준 랭크를 좀 올리고 프로그래머스를 해야겠다. 그티어에 잠이오냐?? 아 물론 앞으로 알고리즘 문제는 많이 안올라갈거다. 이것저것 준비하는게 있다보니 알고리즘보다는 안드로이드에 더 비중을 많이 두고있다. 그래서 개발을 더 많이 하고있고, 앞으로도 더 많이 할 것 같다. 하면서 ..

[Kotlin] Programmers 코딩 기초 트레이닝 Day 25 이차원 리스트(배열)

정수를 나선형으로 배치하기 class Solution { val dir = arrayOf( arrayOf(0, 1, 0, -1), arrayOf(1, 0, -1, 0) ) fun solution(n: Int): Array { var answer: Array = arrayOf() for (i in 0 until n) { answer += IntArray(n) } var cnt = 1; var dirIdx = 0; var x = 0 var y = 0 while (cnt = n || y = n) && answer[x][y] == 0) { answer[x][y] = cnt++ x += dir[0][dirIdx] y += dir[1][dirIdx] } x -= dir[0][dirIdx] y -=..

[Kotlin] Programmers 코딩 기초 트레이닝 Day 24 조건문 활용, 반복문 활용, 이차원 리스트(배열)

커피 심부름 class Solution { fun solution(order: Array): Int = order.count { it.contains("cafelatte") } * 5000 + (order.size - order.count { it.contains("cafelatte") })*4500 } 그림 확대 class Solution { fun solution(picture: Array, k: Int): Array { var result = arrayOf() for (i in picture){ var temp = "" for (j in 0 until i.length){ repeat(k){ temp += i[j] } } repeat(k){ result = result.plus(temp) } } re..

[Kotlin] Programmers 코딩 기초 트레이닝 Day 23 조건문 활용

부분 문자열 class Solution { fun solution(str1: String, str2: String): Int = if (str2.contains(str1)) 1 else 0 } 꼬리 문자열 class Solution { fun solution(str_list: Array, ex: String): String = str_list.filter { !it.contains(ex) }.joinToString("") } 정수 찾기 class Solution { fun solution(num_list: IntArray, n: Int): Int = if (num_list.contains(n)) 1 else 0 } 주사위 게임 1 import kotlin.math.abs class Solution { f..

[Kotlin] Programmers 코딩 기초 트레이닝 Day 22 함수(메서드)

0 떼기 fun solution(n_str: String): String { var result = n_str while (result.startsWith('0')){ result = result.slice(1 until result.length) } return result } //fun solution(n_str: String): String = n_str.toInt().toString() 두 수의 합 class Solution { fun solution(a: String, b: String): String = "${a.toBigInteger() + b.toBigInteger()}" } 문자열로 변환 class Solution { fun solution(n: Int): String = n.toStri..