Categories: SWEA

SWEA 2805 농작물 수확하기 D3 (자바 Java)

SWEA 2805 농작물 수확하기

문제 정보

  • 문제 출처 : SW Expert Academy
  • 문제 번호 : 2805
  • 문제 제목 : 농작물 수확하기
  • 문제 난이도 : D3
  • 풀이 언어 : Java

문제

N x N 크기의 농장이 격자 모양으로 구성되어 있으며, 각 격자 칸에는 농작물의 가치가 표시되어 있다. 이 농장에서는 특별히 중앙에서 시작하여 마름모 모양으로 농작물을 수확한다. 마름모 구역 내의 농작물 가치의 합을 구하는 문제

접근

각 줄에서 중앙으로부터의 거리에 따라 수확 범위를 결정하고, 해당 범위 내의 값들을 더하여 문제를 풀었다.

풀이

  • 첫 줄에는 테스트 케이스 개수 T 가 주어진다.
  • for 반복문을 사용하여 T번의 테스트 케이스를 처리한다.
  • 각 테스트 케이스에서 농장의 크기 N을 입력 받는다.
  • N x N 크기의 정수형 배열 farm을 선언한다.
  • 중첩된 for 반복문을 사용하여 농장의 각 줄에 대한 데이터를 입력 받는다.
  • 문자열 row를 통해 각 줄의 데이터를 읽어들인다.
  • 내부 for 반복문을 통해 row의 각 문자를 숫자로 변환하여 farm 배열에 저장한다.
  • 농장의 중앙을 나타내는 center 변수를 계산한다.
  • 중첩된 for 반복문을 사용하여 마름모 모양의 농작물 수확 구역을 계산한다.
  • distance 변수를 사용하여 각 행에서 중앙으로부터의 거리를 계산한다.
  • 내부 for 반복문을 통해 해당 행의 distance부터 N – distance까지의 농작물 가치를 합산한다.
  • 각 테스트 케이스의 결과를 출력한다.

후기

마름모 형태의 수확 구역을 계산하는 것이 처음에는 복잡해 보였지만, 중앙으로부터의 거리 개념을 사용하니 조금 수월하게 풀 수 있었습니다.

코드

Java
import java.util.Scanner;
import java.io.FileInputStream;
 
class Solution
{
    public static void main(String args[]) throws Exception
    {
        Scanner sc = new Scanner(System.in);
        int T;
        T=sc.nextInt();
 
        for(int test_case = 1; test_case <= T; test_case++)
        {
            int N = sc.nextInt();
            int[][] farm = new int[N][N];
            int total = 0;
 
            for (int i = 0; i < N; i++) {
                String row = sc.next();
                for (int j = 0; j < N; j++) {
                    farm[i][j] = row.charAt(j) - '0';
                }
            }
             
            int center = N / 2;
            for (int i = 0; i < N; i++) {
                int distance = Math.abs(center - i);
                for (int j = distance; j < N - distance; j++) {
                    total += farm[i][j];
                }
            }
            System.out.println("#" + test_case + " " + total);
        }
        sc.close();
    }
}
Java
suover

View Comments

  • Howdy just wanted to give you a quick heads up. The words in your content seem to be running off the
    screen in Firefox. I'm not sure if this is a format
    issue or something to do with browser compatibility but I thought I'd post to let you know.
    The style and design look great though! Hope you get the issue fixed soon. Thanks

  • It’s the best time to make some plans for the long
    run and it’s time to be happy. I’ve read this publish and if I may I want to suggest you few attention-grabbing
    issues or tips. Perhaps you can write subsequent articles relating to
    this article. I want to learn even more things about it!

Recent Posts

Spring 스프링 컴포넌트 스캔(Component Scan)이란?

컴포넌트 스캔이란? 컴포넌트 스캔(Component Scan)은 스프링 프레임워크가 특정 패키지를 탐색하면서, 스캔 대상에 해당하는 클래스를 찾아…

2주 ago

Spring 스프링 빈(Bean)이란?

스프링 빈이란? 스프링 빈(Spring Bean)은 스프링 IoC(Inversion of Control) 컨테이너가 관리하는 자바 객체를 의미합니다. 간단히…

3주 ago

Spring 스프링 컨테이너(Spring Container)란?

스프링 컨테이너(Spring Container)란? 스프링 컨테이너는 스프링 프레임워크에서 가장 핵심적인 부분으로, IoC(Inversion of Control) 개념을 기반으로…

1개월 ago

Java 자바 큐(Queue) 개념과 사용법

Queue란 무엇인가? Java에서 Queue는 데이터 구조의 일종으로, 데이터를 선입선출(FIFO, First-In-First-Out) 방식으로 처리합니다. 이 글에서는 Queue의…

1개월 ago

Java 자바 스택(Stack) 개념과 사용법

Stack이란 무엇인가? Java에서 Stack은 자료구조의 한 종류로, 데이터를 순서대로 쌓아 올리는 형태로 운영됩니다. 컴퓨터 과학에서…

2개월 ago

Java 자바 Map – HashMap, TreeMap, LinkedHashMap 정리

소개 자바에서 Map 인터페이스는 키(Key)와 값(Value)의 쌍을 저장하는 자료구조입니다. 이는 연관 배열이라고도 불리며, 각 키는…

2개월 ago