반응형

https://www.acmicpc.net/problem/10809

 

10809번: 알파벳 찾기

각각의 알파벳에 대해서, a가 처음 등장하는 위치, b가 처음 등장하는 위치, ... z가 처음 등장하는 위치를 공백으로 구분해서 출력한다. 만약, 어떤 알파벳이 단어에 포함되어 있지 않다면 -1을 출

www.acmicpc.net

제 풀이도 나름 풀었다고 생각했는데 

다른 스터디원은 indexOf 메서드를 활용하여 매우 간편하게 풀었더군요. 

제 답이 틀린건 아니지만 해당 메서드를 생각했더라면 더 간단히 풀었겠다는 생각을 했습니다.

풀이 과정에는 정답이 없으니 ... 하지만 indexof를 생각 못한 저에게 현타가 잠깐왔다가 회복한 상태입니다. ㅎㅎㅎ

package com.ji.beakjoon;

import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;

public class Alphabet {

	/**
	 * 알파벳 찾기
	 * 
	 * @param args
	 * @throws IOException
	 */
	static int lowerCaseRangeSize = 122 - 97;
	static int lowerCaseStartIndex = 97;
	static int lowerCaseEndIndex = 122;

	public static void main(String[] args) throws IOException {

		BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out));

		String input = br.readLine();
		
		int[] resultArr = new int[lowerCaseRangeSize+1];
		for (int j = lowerCaseStartIndex; j <= lowerCaseEndIndex; j++) {

			int alphabetCnt = 0;
			for (int i = 0; i < input.length(); i++) {

				if (input.charAt(i) == j) {
					alphabetCnt++;

					//연속 문자열 첫번째 인덱스만 저장
					if (alphabetCnt == 1)
						resultArr[j - lowerCaseStartIndex] = i;
				}

			}
			
			if (alphabetCnt == 0)
				resultArr[j - lowerCaseStartIndex] = -1;
			
		}

		for (int index : resultArr)
			bw.write(String.valueOf(index) + " ");

		br.close();
		bw.flush();
		bw.close();

	}

}

 

 

728x90

'[개발관련] > 코테준비' 카테고리의 다른 글

[백준] 동전1  (0) 2021.07.11
[백준] 안전영역  (0) 2021.07.11
[백준] 트리의 부모찾기  (0) 2021.06.20
[백준] 트리순회  (0) 2021.06.20
[백준] 구슬탈출 4 for JAVA  (0) 2021.06.20

+ Recent posts