기록하는 개발자

[백준 2711번] 오타맨 고창영 - JAVA 알고리즘 본문

Baekjoon Online Judge

[백준 2711번] 오타맨 고창영 - JAVA 알고리즘

gitseok 2022. 3. 29. 16:25

2711번
문제
고창영은 맨날 오타를 낸다. 창영이가 오타를 낸 문장과 오타를 낸 위치가 주어졌을 때, 오타를 지운 문자열을 출력하는 프로그램을 작성하시오.
창영이는 오타를 반드시 1개만 낸다.
입력
첫째 줄에 테스트 케이스의 개수 T(1<=T<=1,000)가 주어진다. 각 테스트 케이스는 한 줄로 구성되어 있다. 첫 숫자는 창영이가 오타를 낸 위치이고, 두 번째 문자열은 창영이가 친 문자열이다. 문자열의 가장 첫 문자는 1번째 문자이고, 문자열의 길이는 80을 넘지 않고, 대문자로만 이루어져 있다. 오타를 낸 위치는 문자열 길이보다 작거나 같다.
출력
각 테스트 케이스에 대해 오타를 지운 문자열을 출력한다.
예제 입력 예제 출력
   
4
4 MISSPELL
1 PROGRAMMING
7 CONTEST
3 BALLOON
ISPELL
ROGRAMMING
CONTES
BALOON
import java.io.BufferedReader;
import java.io.BufferedWriter;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.OutputStreamWriter;
import java.util.StringTokenizer;

public class Main {

	public static void main(String[] args) throws IOException {
		// TODO Auto-generated method stub
		BufferedReader br = new BufferedReader(new InputStreamReader(System.in)); // 선언
		BufferedWriter bw = new BufferedWriter(new OutputStreamWriter(System.out)); // 선언

		int N = Integer.parseInt(br.readLine());
		
		String[] word = new String[N];

		for(int i=0; i<N; i++) {
			StringTokenizer st = new StringTokenizer(br.readLine());
			int typoNum = Integer.parseInt(st.nextToken());
			String typoWord = st.nextToken();
			word[i] = "";
			for(int j=0;j<typoWord.length();j++) {
			
				if(!(j == typoNum-1)) {
					word[i] = word[i]+typoWord.charAt(j);
					}		
			}
			if(i-1==N) {
				bw.write(word[i]+"");	
			}else {
				bw.write(word[i]+"\n");	
			}
		}
		bw.close();
		br.close();
	}
}

 

 

실행 결과

개인적으로 정리한 내용을 간단하게 풀어 작성했습니다.
이해가 안가는 부분은 댓글 남겨주시면 설명해드리겠습니다.
Comments