반응형
츄르사려고 코딩하는 코집사입니다.
1. [백준 알고리즘] 백준 11283번 한글2 자바(Java)
1) 문제번호 : 11283번
2) 문제 출처
2. 문제
한글의 각 글자는 초성, 중성, 종성으로 이루어져 있고, 이 세 가지를 모아써서 한 글자를 나타낸다.
초성은 ㄱ, ㄲ, ㄴ, ㄷ, ㄸ, ㄹ, ㅁ, ㅂ, ㅃ, ㅅ, ㅆ, ㅇ, ㅈ, ㅉ, ㅊ, ㅋ, ㅌ, ㅍ, ㅎ로 총 19개가 있고, 중성은 ㅏ, ㅐ, ㅑ, ㅒ, ㅓ, ㅔ, ㅕ ㅖ, ㅗ, ㅘ, ㅙ, ㅚ, ㅛ, ㅜ, ㅝ, ㅞ, ㅟ, ㅠ, ㅡ, ㅢ, ㅣ로 총 21개, 종성은 없음, ㄱ, ㄲ, ㄳ, ㄴ, ㄵ, ㄶ, ㄷ, ㄹ, ㄺ, ㄻ, ㄼ, ㄽ, ㄾ, ㄿ, ㅀ, ㅁ, ㅂ, ㅄ, ㅅ, ㅆ, ㅇ, ㅈ, ㅊ, ㅋ, ㅌ, ㅍ, ㅎ로 총 28개가 있다.
첫 번째 글자는 초성에서 ㄱ, 중성에서 ㅏ, 종성에서 없음을 합친 "가"가 되고, 두 번째 글자는 초성에서 ㄱ, 중성에서 ㅏ, 종성에서 ㄱ을 합친 "각"이 된다. 마지막 글자는 초성에서 ㅎ, 중성에서 ㅣ, 종성에서 ㅎ를 합친 "힣"이 된다.
초성과 중성, 그리고 종성을 합쳐서 만들 수 있는 글자의 개수는 총 19*21*28 = 11,172개가 된다.
한글이 주어졌을 때, 몇 번째 글자인지 구하는 프로그램을 작성하시오.
3. 제약사항
-
4. 입력
첫째 줄에 글자 하나가 주어진다. 주어지는 글자는 UTF-8로 인코딩 되어 있는 한글이며, 문제 설명에 나온 방법으로 만들 수 있다.
5. 출력
입력으로 주어진 글자가 몇 번째인지 출력한다.
6. 풀이
- String형으로 받아서 char형으로 바꾸고, char형을 int형으로 변환하여 44031을 빼주면 된다.
7. 소스 코드
import java.math.BigInteger;
import java.util.*;
public class Main {
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
String a = sc.next();
char result = a.charAt(0);
System.out.println(((int) result) - 44031);
}
}
반응형
'알고리즘 > 백준 알고리즘' 카테고리의 다른 글
[백준 알고리즘] 백준 10870번 피보나치 수5 자바(Java) (0) | 2021.03.23 |
---|---|
[백준 알고리즘] 백준 20944번 팰린드롬 척화비 자바(Java) (0) | 2021.03.23 |
[백준 알고리즘] 백준 10707번 수도요금 자바(Java) (0) | 2021.03.20 |
[백준 알고리즘] 백준 15727번 조별과제를 하려는데 조장이 사라졌다 자바(Java) (0) | 2021.03.20 |
[백준 알고리즘] 백준 15894번 수학은 체육과목 입니다 자바(Java) (0) | 2021.03.20 |
[백준 알고리즘] 백준 1010번 다리 놓기 자바(Java) (0) | 2021.03.20 |
[백준 알고리즘] 백준 20492번 세금 자바(Java) (0) | 2021.03.19 |
[백준 알고리즘] 백준 11478번 서로 다른 부분 문자열의 개수 자바(Java) (1) | 2021.03.19 |
최근댓글