16139번

2023. 1. 2. 11:52·CS 이론/알고리즘
728x90

https://www.acmicpc.net/problem/16139

 

16139번: 인간-컴퓨터 상호작용

첫 줄에 문자열 $S$가 주어진다. 문자열의 길이는 $200,000$자 이하이며 알파벳 소문자로만 구성되었다. 두 번째 줄에는 질문의 수 $q$가 주어지며, 문제의 수는 $1\leq q\leq 200,000$을 만족한다. 세 번째

www.acmicpc.net

처음 이 문제를 봤을 때는 그냥 주어진 문자열과 주어진 시작,끝 인덱스를 이용해서 비교값과 같으면 count값을 증가시키는 방식을 생각해냈다.

하지만 그렇게 했더니 50점만 받을 수 있었다. 이 문제에서 바라는 것은 누적합계산이었다. 즉, 값 저장 배열을 만들어서 누적된 계산의 합을 구하라는 것이다.

그래서 표를 만들었다. joon이라는 문자열이 주어졌다고 가정 했을 때 표를 채워보면, 행의 길이는 주어진 문자열의 길이이고, 열은 알파벳 26자리 이다.

  a b c d e f g h i j k l m n o p q r
0                   1                
1                             1      
2                             2      
3                           1        

위의 표처럼 joon에 대해서 순서대로 j는 j의 칸의 값을 증가 시키고 o는 o의 칸을 증가시킨다. 그리고 n도 마찬가지로 한다.

그럼 이 방식을 사용해서 코드를 짠다면 주어진 끝지점 인덱스에서 시작지점 인덱스-1지점을 빼면 시작지점과 끝지점 사이에 있는 누적 알파벳의 수가 나온다. 위 표를 예로들어 o 1 2라고 주어진다면 2-0으로 2가 나온다.

 

정답 코드는 아래와 같다.

 

package backjoon;

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

public class b16139 {
    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        String target = br.readLine();
        int test = Integer.parseInt(br.readLine());
        int[][] alpha = new int[target.length()][26];

        alpha[0][target.charAt(0)-'a']++;//for문을 0으로 시작할 수 없어서 초기화해준다.
		//0으로 시작하면 인덱스 exception이 발생한다.
        for(int i=1;i<target.length();i++){
            int tmp = target.charAt(i)-'a';
            for(int j=0; j<26; j++){
                alpha[i][j]=alpha[i-1][j];//이전 행에서 추가한 값을 복사해온다.
            }
            alpha[i][tmp]++;//새로 누적되는 값을 증가시킨다.
        }
        StringBuilder sb = new StringBuilder();
        for(int i=0; i<test; i++){
            StringTokenizer st = new StringTokenizer(br.readLine());
            char comp=st.nextToken().charAt(0);
            int start = Integer.parseInt(st.nextToken());
            int end = Integer.parseInt(st.nextToken());
            if(start==0){
                sb.append(alpha[end][comp-'a']).append("\n");
            }//시작지점이 0일때는 끝지점의 값이 누적 값이다.
            else sb.append(alpha[end][comp-'a']-alpha[start-1][comp-'a']).append("\n");
        }//끝지점에서 시작지점-1지점을 빼는 것은 시작지점 또한 누적 값에 포함하기 위해서이다.
        System.out.println(sb);
    }
}
728x90

'CS 이론 > 알고리즘' 카테고리의 다른 글

24060번  (0) 2023.01.05
25682번  (1) 2023.01.03
15666번  (3) 2023.01.01
15663번  (0) 2022.12.31
1003번  (2) 2022.12.29
'CS 이론/알고리즘' 카테고리의 다른 글
  • 24060번
  • 25682번
  • 15666번
  • 15663번
Bello's
Bello's
개발하는 벨로
  • Bello's
    벨로의 개발일지
    Bello's
  • 전체
    오늘
    어제
    • 분류 전체보기 (199) N
      • 노예 일지 (7)
        • 스타트업 노예일지 (3)
      • CS 이론 (81)
        • 학과 수업 (4)
        • 알고리즘 (64)
        • 시스템 프로그래밍 (3)
        • 데이터 통신 (1)
        • 운영체제 (2)
        • 데이터베이스 (1)
      • project (3)
      • 나는 감자다. (4)
      • Spring (27)
      • 모각코 (45)
        • 절개와지조(모각코) (7)
        • 어쩌다보니 박준태가 조장이조 (11)
        • 어쩌다보니 박준태가 또 조장이조 (12)
      • LikeLion🦁 (20)
      • 캘리포니아 감자 (4)
      • OpenSource Contribute (1)
      • 우아한테크벨로 (1) N
        • 프리코스 회고록 (6)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    감자
    BFS
    타임리프
    오블완
    프리코스
    뛰슈
    절개와지조
    어렵다
    티스토리챌린지
    회고록
    자바
    나는 감자
    모각코
    누적합
    JPA
    백준
    8기
    Spring
    DFS
    그래프 순회
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.5
Bello's
16139번
상단으로

티스토리툴바