Carnival7
Change Developer
Carnival7
전체 방문자
오늘
어제
  • 분류 전체보기
    • 자바의 정석
    • 프로그래밍 언어별 tools
      • 파이썬
      • 자바
    • 코딩 테스트
      • 백준 강의 기초편
      • 백준 강의 연습편
      • 백준 강의 문제편
      • 삼성 기출
      • 백준 - 일반
      • 카카오 기출
      • 프로그래머스 - 일반
      • 코테 풀이 Tools
    • CS
      • Network
      • 운영체제
      • 알고리즘
      • DB
    • Web_Backend
      • Spring
      • 스프링 MVC 1편 - 백엔드 웹 개발 핵심 기술
      • 스프링 핵심 원리 - 기본편
    • DevOps
    • IT 업무 지식
      • 인프라
      • 클라우드
    • 자격증
      • AWS - CLF
      • 정처기 - 실기
    • 생각 정리

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 삼성기출 #백준강의문제편
  • 슬라이딩 윈도우
  • 스프링 #AOP
  • DevOps
  • 프로그래머스 #카카오기출 #레벨2
  • Github Actions
  • code deploy
  • 슬라이딩 윈도우 #덱
  • 스프링 부트 무중단 웹 서비스
  • 알고리즘 #백준강의기초편 #코딩테스트
  • ci/cd
  • 스프링 #인터셉터 #AOP #필터
  • DMZ
  • 삼성기출 #2023 #상반기
  • 코딩테스트 #삼성기출 #구현 #시뮬레이션
  • nginx

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
Carnival7

Change Developer

코딩 테스트/백준 - 일반

2531. 회전 초밥, 15961. 회전 초밥

2023. 1. 28. 22:52

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

 

2531번: 회전 초밥

첫 번째 줄에는 회전 초밥 벨트에 놓인 접시의 수 N, 초밥의 가짓수 d, 연속해서 먹는 접시의 수 k, 쿠폰 번호 c가 각각 하나의 빈 칸을 사이에 두고 주어진다. 단, 2 ≤ N ≤ 30,000, 2 ≤ d ≤ 3,000, 2 ≤

www.acmicpc.net

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

 

15961번: 회전 초밥

첫 번째 줄에는 회전 초밥 벨트에 놓인 접시의 수 N, 초밥의 가짓수 d, 연속해서 먹는 접시의 수 k, 쿠폰 번호 c가 각각 하나의 빈 칸을 사이에 두고 주어진다. 단, 2 ≤ N ≤ 3,000,000, 2 ≤ d ≤ 3,000, 2

www.acmicpc.net

import sys
input=sys.stdin.readline

n,d,k,c=map(int,input().split())
a=[]
for i in range(n):
    a.append(int(input()))

b=[0]*(d+1)
b[c]=1
cnt=1
ans=0

for i in range(k):
    if b[a[i]]==0:
        cnt+=1
    b[a[i]]+=1
ans=max(ans,cnt)

for i in range(k,n):
    j=i-k
    if b[a[i]]==0:
        cnt+=1
    b[a[i]] += 1
    b[a[j]] -= 1
    if b[a[j]] == 0:
        cnt -= 1
    ans=max(ans,cnt)

a=a[n-k+1:]+a[:n-k+1]

b=[0]*(d+1)
b[c]=1
cnt=1

for i in range(k):
    if b[a[i]]==0:
        cnt+=1
    b[a[i]]+=1
ans=max(ans,cnt)

for i in range(k,k+(n-1-k)):
    j=i-k
    if b[a[i]]==0:
        cnt+=1
    b[a[i]] += 1
    b[a[j]] -= 1
    if b[a[j]] == 0:
        cnt -= 1
    ans=max(ans,cnt)

print(ans)

'코딩 테스트 > 백준 - 일반' 카테고리의 다른 글

3078. 좋은 친구  (1) 2023.01.28
1593. 문자 해독  (0) 2023.01.28
11003. 최솟값 찾기  (0) 2023.01.28
    '코딩 테스트/백준 - 일반' 카테고리의 다른 글
    • 3078. 좋은 친구
    • 1593. 문자 해독
    • 11003. 최솟값 찾기
    Carnival7
    Carnival7

    티스토리툴바