얼음녹차의 블로그
article thumbnail

문제 링크: https://school.programmers.co.kr/learn/courses/30/lessons/147355

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

 

처음 작성한 코드

  • p의 문자열 길이만큼 t의 문자열을 잘라 정수로 변환한 뒤 크기를 비교한다.
  • 범위는 문자열 t의 길이에서 문자열 p의 길이를 빼고 1을 정해준다.
    • 만약 p가 10의 길이, t가 3의 길이를 가진다면 0~2, ..., 8~10의 인덱스를 지정해주어야 하기 때문
def solution(t, p):
    answer = 0
    p_len = len(p)
    for i in range(len(t) - p_len + 1):
        if int(t[i:i+p_len]) <= int(p):
            answer += 1
    return answer

# 입출력 예시
print(solution("3141592", "271"))
print(solution("500220839878", "7"))
print(solution("10203", "15"))

 

다른 코드

사소한 차이는 있으나 크게 다른 코드, 혹은 더 좋은 코드를 발견하지 못했다.

profile

얼음녹차의 블로그

@PERIR

포스팅이 좋았다면 "좋아요❤️" 또는 "구독👍🏻" 해주세요!