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
- 객체
- 안드로이드 유닛테스트란
- 서비스 vs 쓰레드
- rxjava cold observable
- 큐 자바 코드
- 2022 플러터 안드로이드 스튜디오
- 안드로이드 라이선스
- 안드로이드 유닛 테스트
- 스택 자바 코드
- 2022 플러터 설치
- 안드로이드 레트로핏 사용법
- android ar 개발
- 멤버변수
- 자바 다형성
- jvm 작동 원리
- 서비스 쓰레드 차이
- jvm이란
- 클래스
- 플러터 설치 2022
- rxjava disposable
- android retrofit login
- 안드로이드 레트로핏 crud
- 안드로이드 라이선스 종류
- 안드로이드 os 구조
- ar vr 차이
- 안드로이드 유닛 테스트 예시
- rxjava hot observable
- ANR이란
- 스택 큐 차이
- Rxjava Observable
Archives
- Today
- Total
나만을 위한 블로그
[Algorithm] 백준 - 알파벳 찾기 (10809) (Kotlin) 본문
728x90
반응형
주어진 문자열에서 각 알파벳들의 등장 위치를 구하는 문제인데 아스키 값을 사용하면 쉽게 풀 수 있다.
알파벳 문자들은 컴퓨터 내부에서 숫자로 표현된다. 이 숫자가 아스키 값(ascii value)이라 불리는데, 위치를 구하고자 하는 알파벳에서 'a'를 빼면 그 알파벳의 위치를 알 수 있다. 이를 정수 배열에 적용하면 이 문제와 같이 알파벳 위치 별 등장 여부를 확인하거나, 등장 횟수를 카운트할 때 활용할 수 있다.
fun main() {
val word = readln()
val positions = IntArray(26) { -1 }
for (i in word.indices) {
val char = word[i]
val alphabetIndex = char - 'a'
if (positions[alphabetIndex] == -1) {
positions[alphabetIndex] = i
}
}
println(positions.joinToString(" "))
}
a~z까지 개수는 26이니 크기가 26인 정수 배열을 만들고 -1로 초기화한다. 이렇게 해야 등장하지 않은 알파벳의 인덱스에 -1이 들어간다.
그리고 입력받은 문자열의 인덱스를 순회하면서(indices) 각 인덱스 별 알파벳을 가져온다. 이 때 앞서 말한 것처럼 'a'를 빼면 그 알파벳의 위치를 알 수 있다.
이제 아스키 값을 활용해 본다. a의 아스키 값은 97이다. b는 98, c는 99 식으로 1씩 증가하는데 만약 b의 위치를 구하고자 한다면 b-a, 즉 98-97이 된다.
이 식의 값은 1이기 때문에 1번 인덱스가 곧 b의 위치가 된다. 만약 알파벳이 등장하지 않으면 처음 배열을 초기화할 때 -1을 사용했으니 그대로 -1이 된다.
아스키 문자와 숫자들은 아래 링크에서 테이블 형태로 확인할 수 있다.
반응형
'알고리즘 문제 풀이 > 백준' 카테고리의 다른 글
[Algorithm] 백준 - 알람 시계 (2884) (Kotlin) (0) | 2024.07.06 |
---|---|
[Algorithm] 백준 - 아스키 코드 (11654) (Kotlin) (0) | 2024.06.07 |
[Algorithm] 백준 - 음계 (2920) (Kotlin) (0) | 2024.06.06 |
[Algorithm] 백준 - 알람 시계 (2884) (Kotlin) (0) | 2024.06.06 |
[Algorithm] 백준 - 숫자의 개수 (2577) (Kotlin) (0) | 2024.06.06 |
Comments