Notice
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 안드로이드 유닛테스트란
- rxjava hot observable
- 플러터 설치 2022
- 스택 자바 코드
- android retrofit login
- 스택 큐 차이
- 안드로이드 레트로핏 사용법
- 2022 플러터 안드로이드 스튜디오
- ANR이란
- 안드로이드 라이선스
- 큐 자바 코드
- 안드로이드 레트로핏 crud
- 서비스 vs 쓰레드
- 객체
- Rxjava Observable
- 안드로이드 유닛 테스트
- jvm이란
- 클래스
- 자바 다형성
- rxjava disposable
- 안드로이드 유닛 테스트 예시
- 서비스 쓰레드 차이
- 안드로이드 os 구조
- ar vr 차이
- 멤버변수
- 안드로이드 라이선스 종류
- 2022 플러터 설치
- jvm 작동 원리
- rxjava cold observable
- android ar 개발
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 프로그래머스 - 정수를 나선형으로 배치하기 (Kotlin) 본문
728x90
반응형
양의 정수 n이 매개변수로 주어진다. n x n 배열에 1부터 n^2까지 정수를 인덱스 [0][0]부터 시계방향 나선형으로 배치한 2차원 배열을 리턴하는 함수를 작성하라
class Solution {
fun solution(n: Int): Array<IntArray> {
val result = Array(n) { IntArray(n) }
var value = 1
var x = 0
var y = 0
var direction = 0
val dx = arrayOf(0, 1, 0, -1)
val dy = arrayOf(1, 0, -1, 0)
while (value <= n * n) {
result[x][y] = value
value++
var nx = x + dx[direction]
var ny = y + dy[direction]
if (nx !in 0 until n || ny !in 0 until n || result[nx][ny] != 0) {
direction = (direction + 1) % 4
nx = x + dx[direction]
ny = y + dy[direction]
}
x = nx
y = ny
}
return result
}
}
반응형
'알고리즘 문제 풀이 > 프로그래머스' 카테고리의 다른 글
[Algorithm] 프로그래머스 - 정사각형으로 만들기 (Kotlin) (0) | 2024.07.06 |
---|---|
[Algorithm] 프로그래머스 - 특별한 이차원 배열 2 (Kotlin) (0) | 2024.07.06 |
[Algorithm] 프로그래머스 - 특별한 이차원 배열 1 (Kotlin) (0) | 2024.07.04 |
[Algorithm] 프로그래머스 - l로 만들기 (Kotlin) (0) | 2024.07.04 |
[Algorithm] 프로그래머스 - 조건에 맞게 수열 변환하기 3 (Kotlin) (0) | 2024.07.04 |
Comments