Logo
(追記) (追記ここまで)

13550번 - 수열과 쿼리 7

시간 제한메모리 제한제출정답맞힌 사람정답 비율
4 초 512 MB207867450729.859%

문제

길이가 N인 수열 A1, A2, ..., AN과 정수 K가 주어진다. 이때, 다음 쿼리를 수행하는 프로그램을 작성하시오.

  • l r: l ≤ i ≤ j ≤ r이면서 (Ai + Ai+1 + ...+ Aj) mod K = 0인 가장 긴 연속 부분 수열의 길이를 출력한다.
    • 조건을 만족하는 부분 수열이 존재하지 않는 경우 길이는 0이다.

입력

첫째 줄에 수열의 크기 N (1 ≤ N ≤ 100,000)과 K (2 ≤ K ≤ 1,000,000)이 주어진다.

둘째 줄에는 A1, A2, ..., AN이 주어진다. (1 ≤ Ai ≤ 1,000,000,000)

셋째 줄에는 쿼리의 개수 M (1 ≤ M ≤ 100,000)이 주어진다.

넷째 줄부터 M개의 줄에는 쿼리 l, r이 한 줄에 하나씩 주어진다. (1 ≤ l ≤ r ≤ n)

출력

각각의 쿼리마다 정답을 한 줄에 하나씩 출력한다.

제한

예제 입력 1

5 10
2 3 5 2 3
2
1 3
2 4

예제 출력 1

3
3

힌트

출처

(追記) (追記ここまで)

출처

대학교 대회

  • 사업자 등록 번호: 541-88-00682
  • 대표자명: 최백준
  • 주소: 서울시 서초구 서초대로74길 29 서초파라곤 412호
  • 전화번호: 02-521-0487 (이메일로 연락 주세요)
  • 이메일: contacts@startlink.io
  • 통신판매신고번호: 제 2017-서울서초-2193 호

AltStyle によって変換されたページ (->オリジナル) /