본문 바로가기

카테고리 없음

[Java] 백준 3003번 킹, 퀸, 룩, 비숍, 나이트, 폰

문제

동혁이는 오래된 창고를 뒤지다가 낡은 체스판과 피스를 발견했다.

체스판의 먼지를 털어내고 걸레로 닦으니 그럭저럭 쓸만한 체스판이 되었다. 하지만, 검정색 피스는 모두 있었으나, 흰색 피스는 개수가 올바르지 않았다.

체스는 총 16개의 피스를 사용하며, 킹 1개, 퀸 1개, 룩 2개, 비숍 2개, 나이트 2개, 폰 8개로 구성되어 있다.

동혁이가 발견한 흰색 피스의 개수가 주어졌을 때, 몇 개를 더하거나 빼야 올바른 세트가 되는지 구하는 프로그램을 작성하시오.

입력

첫째 줄에 동혁이가 찾은 흰색 킹, 퀸, 룩, 비숍, 나이트, 폰의 개수가 주어진다. 이 값은 0보다 크거나 같고 10보다 작거나 같은 정수이다.

출력

첫째 줄에 입력에서 주어진 순서대로 몇 개의 피스를 더하거나 빼야 되는지를 출력한다. 만약 수가 양수라면 동혁이는 그 개수 만큼 피스를 더해야 하는 것이고, 음수라면 제거해야 하는 것이다.

예제 입력 1 복사

0 1 2 2 2 7

예제 출력 1 복사

1 0 0 0 0 1

예제 입력 2 복사

2 1 2 1 2 1

예제 출력 2 복사

-1 0 0 1 0 7

 

정답 코드

import java.util.Scanner;
import java.util.Arrays;

public class Main {
  public static void main(String[] args) {    
    int[] arr = new int[] {1, 1, 2, 2, 2, 8}; // 배열 생성
    int[] arr2 = new int[6];
    int[] result = new int[6];
    
    Scanner sc = new Scanner(System.in);
    for(int i=0; i<arr.length; i++){
      int input = sc.nextInt();
      arr2[i] =  input;
    }  
    sc.close();

  for(int j=0; j<arr.length; j++)
	result[j]=arr[j]-arr2[j];
    
  for(int k=0; k<result.length; k++)
    System.out.printf(result[k]+" ");
  
  }
}

배열과 친해지자

 

import java.util.Arrays; 
	System.out.println(Arrays.toString(arr));

을 사용하니까 

1 0 0 0 0 1이 아니라 

{1, 0, 0, 0, 0, 1} 형태로 출력되기에 반복문으로 출력형태를 변경했다