Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 | 9 | 10 | 11 | 12 | 13 | 14 |
15 | 16 | 17 | 18 | 19 | 20 | 21 |
22 | 23 | 24 | 25 | 26 | 27 | 28 |
29 | 30 | 31 |
Tags
- OOP
- Spring MVC 구성요소
- 코드스테이츠 백엔드
- vm인스턴스생성
- Spring MVC 동작원리
- Array.asList
- 11659
- 인텔리제이
- 코드스테이츠
- 싱글톤패턴
- GCP
- MySQL
- 버블정렬
- List.of
- String.valueOf()
- 재귀함수
- 구간합구하기
- java
- 재귀와반복문
- 코딩테스트
- 스택
- 프로그래머스
- 클라우드에서 도커 실행하기
- 자바
- 백준
- 성능테스트툴
- 투포인터알고리즘
- 백준 11659
- Spring Web MVC
- 알고리즘
Archives
- Today
- Total
순간을 기록으로
[HakerRank] 2D Array - DS | 모래시계 모양으로 배열 탐색 본문
풀이
// 전체 배열에서 모래 시계를 오른쪽으로 한 칸씩 이동한다.
// 만약 끝에 도달하면 한 칸 아래 맨 왼쪽으로 가서 반복한다.
// 만약 오른쪽 끝에 도달하고 밑에 칸도 없으면 종료한다.
// 모래시계 왼쪽상한 원소를 기준으로 모래시계 모양의 원소들의 합을 구한다.
// 처음 값은 최솟값으로 설정한다
// 만약 이전 값보다 크다면 최댓값 변수를 그 값으로 갱신한다.
// 최댓값 변수를 리턴한다.
소스코드
package 해커랭크.자료구조.배열.TwoDArraysDs;
import java.util.Scanner;
// 전체 배열에서 모래 시계를 오른쪽으로 한 칸씩 이동한다.
// 만약 끝에 도달하면 한 칸 아래 맨 왼쪽으로 가서 반복한다.
// 만약 오른쪽 끝에 도달하고 밑에 칸도 없으면 종료한다.
// 모래시계 왼쪽상한 원소를 기준으로 모래시계 모양의 원소들의 합을 구한다.
// 처음 값은 최솟값으로 설정한다
// 만약 이전 값보다 크다면 최댓값 변수를 그 값으로 갱신한다.
// 최댓값 변수를 리턴한다.
public class Solution {
public static int solution(int[][] arr) {
int max = Integer.MIN_VALUE;
int[] dx = {-1,0,1,0,-1,0,1};
int[] dy = {-1,-1,-1,0,1,1,1};
for (int i=1; i<5;i++) {
for (int j=1; j<5; j++) {
int temp = 0;
for (int k=0; k<7; k++) {
int x = dx[k];
int y = dy[k];
temp += arr[i+y][j+x];
}
max = Math.max(max, temp);
}
}
return max;
}
public static void main(String[] args) {
Scanner in = new Scanner(System.in);
int[][] arr = new int[6][6];
for (int i=0; i<6; i++) {
for (int j=0; j<6; j++) {
arr[i][j] = in.nextInt();
}
}
System.out.println(solution(arr));
}
}
'Problem Solving' 카테고리의 다른 글
[MySQL] 'a'가 3개 이상 들어가는 국가 찾기 (0) | 2022.04.16 |
---|---|
[HackerRank] Binary Tree Nodes | MySQL (0) | 2022.04.13 |
[HackerRank] Arrays - DS | 리스트 역순으로 만들기 (0) | 2022.04.12 |
[LeetCode] Big Countries | MySQL (0) | 2022.04.08 |
[MySQL] 보호소에서 중성화한 동물 | JOIN (0) | 2022.04.07 |
Comments