연권
달콘박스
연권
전체 방문자
56,749
오늘
2
어제
102
  • 전체 (308)
    • Web (22)
      • JavaScript (8)
      • TypeScript (2)
      • Node.js (8)
      • HTML (0)
      • CSS (0)
      • Network (1)
      • Browser (0)
      • Patterns (3)
    • Framwork (4)
      • Vue.js (3)
      • Electron (1)
    • Infra&DevOps (1)
    • Algorithm (246)
    • Database (16)
    • Review (15)
    • Test (4)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

  • 소인수분해 알고리즘 [ javascript ]
    2021.09.08
    소인수분해 알고리즘 [ javascript ]
  • Vue.js에서 infinite scroll 구현하기
    2021.05.27
    Vue.js에서 infinite scroll 구현하기
  • 구름IDE 에서 MySQL 사용하기
    2020.01.09
    구름IDE 에서 MySQL 사용하기
  • JMeter로 REST API 자동 테스트 하기2
    2021.06.24
    JMeter로 REST API 자동 테스트 하기2
  • JMeter로 REST API 자동 테스트 하기1
    2021.06.22
    JMeter로 REST API 자동 테스트 하기1

태그

  • BFS
  • 스택
  • 정렬
  • sql
  • typescript
  • 코딩테스트 연습
  • 진법
  • 재귀
  • 알고리즘
  • 진수
  • javascript
  • 백준
  • 백준ㅇ
  • 동적계획법
  • DP
  • 프로그래머스
  • 문자열
  • 백트레킹
  • MySQL
  • java

최근 댓글

  • 포스팅 잘 보고 가요!
    아이폰 14 pro max
  • 감사합니다 수정하였습니다 :)
    연권
  • mysql.cnf 가 니라 mysqld.cnf 입니다.!!
    ㅇㅇ
  • 안녕하세요. 포스팅 감사합니다.. 저도 Vue-infin⋯
    지돌이
  • 안녕하세요 42서울 재웅시가 가능한가요?
    예나

최근 글

  • Observer Pattern
    2022.06.21
    Observer Pattern
  • Proxy Pattern (JavaScript)
    2022.06.07
    Proxy Pattern (JavaScript)
  • Singleton Pattern (JavaScript)
    2022.06.07
    Singleton Pattern (JavaScript)
  • 타입 좁히기 (Type Guard)
    2022.05.21
    타입 좁히기 (Type Guard)
  • 라인 플러스 면접 후기
    2022.05.13

티스토리

hELLO · Designed By 정상우.
연권

달콘박스

Algorithm

백준 11659번 구간 합 구하기 4 [ Java ]

2021. 4. 30. 15:42
반응형
 

11659번: 구간 합 구하기 4

첫째 줄에 수의 개수 N과 합을 구해야 하는 횟수 M이 주어진다. 둘째 줄에는 N개의 수가 주어진다. 수는 1,000보다 작거나 같은 자연수이다. 셋째 줄부터 M개의 줄에는 합을 구해야 하는 구간 i와 j

www.acmicpc.net

dp를 사용하여

D[1] 1번째 까지의 합

D[2] 2번째 까지의 합 .. 

으로 저장하고

i부터 j까지면

D[j] - D[i]를 하면 맨 첫자리 숫자가 빠지므로 추가적으로 입력받은 + arr[i]를 해줍니다.

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.StringTokenizer;

public class Main {

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringTokenizer st = new StringTokenizer(br.readLine());
        StringBuilder sb = new StringBuilder();
        int N = Integer.parseInt(st.nextToken());
        int M = Integer.parseInt(st.nextToken());
        int[] arr = Arrays.stream(br.readLine().split(" ")).mapToInt(Integer::parseInt).toArray();
        int[] D = new int[N+1];
        for (int i = 1; i <= N; i++)
            D[i] = D[i-1] + arr[i-1];
        while (M-- > 0) {
            StringTokenizer st1 = new StringTokenizer(br.readLine());
            int i = Integer.parseInt(st1.nextToken());
            int j = Integer.parseInt(st1.nextToken());
            sb.append(D[j] - D[i] + arr[i-1] + "\n");
        }
        System.out.print(sb);
    }
}

 

반응형
저작자표시 동일조건
  • 카카오스토리
  • 트위터
  • 페이스북

'Algorithm' 카테고리의 다른 글

백준 1699번 제곱수의 합 [ Java ]  (0) 2021.05.01
백준 18870번 좌표 압축 [ Java ]  (0) 2021.04.30
백준 12852번 1로 만들기 2 [ Java ]  (0) 2021.04.30
프로그래머스 코딩테스트 연습 Level4 - 우유와 요거트가 담긴 장바구니 [ Mysql ]  (0) 2021.04.23
프로그래머스 코딩테스트 연습 Level2 - 점프와 순간 이동 [ Java ]  (0) 2021.04.21
    'Algorithm' 카테고리의 다른 글
    • 백준 1699번 제곱수의 합 [ Java ]
    • 백준 18870번 좌표 압축 [ Java ]
    • 백준 12852번 1로 만들기 2 [ Java ]
    • 프로그래머스 코딩테스트 연습 Level4 - 우유와 요거트가 담긴 장바구니 [ Mysql ]
    DP, 동적계획법, 백준, 알고리즘
    연권
    연권
    댓글쓰기
    다음 글
    백준 18870번 좌표 압축 [ Java ]
    이전 글
    백준 12852번 1로 만들기 2 [ Java ]

    티스토리툴바