[코테준비]프로그래머스 코딩 기초 트레이닝 DAY9 Python <문자열>
https://school.programmers.co.kr/learn/challenges/training?order=acceptance_desc&languages=python3
프로그래머스 코딩 기초 트레이닝 연습풀이입니다. 모든 문제의 저작권은 프로그래머스에게 있으며 문제가 됐을 시 삭제하겠습니다.
DAY9 문자열
배열만들기5
문제설명
문자열 배열 intStrs와 정수 k, s, l가 주어집니다. intStrs의 원소는 숫자로 이루어져 있습니다.
배열 intStrs의 각 원소마다 s번 인덱스에서 시작하는 길이 l짜리 부분 문자열을 잘라내 정수로 변환합니다. 이때 변환한 정수값이 k보다 큰 값들을 담은 배열을 return 하는 solution 함수를 완성해 주세요
intStrs k s l result
["0123456789","9876543210","9999999999999"] | 50000 | 5 | 5 | [56789, 99999] |
슈도코드
기존과 했던 것처럼 동일하게 빈 배열 만들고, 문자열 자른것과 k와 비교해서 빈 배열에 추가한다.
전체코드
def solution(intStrs, k, s, l):
answer = []
for string in intStrs:
substring = string[s:s+l]
num = int(substring)
if num > k:
answer.append(num)
return answer
부분문자열이어붙여문자열만들기
문제설명
길이가 같은 문자열 배열 my_strings와 이차원 정수 배열 parts가 매개변수로 주어집니다. parts[i]는 [s, e] 형태로, my_string[i]의 인덱스 s부터 인덱스 e까지의 부분 문자열을 의미합니다. 각 my_strings의 원소의 parts에 해당하는 부분 문자열을 순서대로 이어 붙인 문자열을 return 하는 solution 함수를 작성해 주세요.
슈도코드
위의 배열만들기 와 동일하게 s~e까지 모아논 문자열 빼놓고 배열 뒤집기 하기
전체코드
def solution(my_strings, parts):
sub = my_strings[s:e+1]
rev = sub[::-1]
return rev
문자열뒤의n글자
문제설명
문자열 my_string과 정수 n이 매개변수로 주어질 때, my_string의 뒤의 n글자로 이루어진 문자열을 return 하는 solution 함수를 작성해 주세요.
my_string n result
"ProgrammerS123" | 11 | "grammerS123" |
"He110W0r1d" | 5 | "W0r1d" |
슈도코드
아무생각없이 처음에 [n:] 했는데 뒤에서부터 세는거니까 -n으로 해야 그만큼의 글자가 나오는 걸 깨달았다..
전체코드
def solution(my_string, n):
answer = my_string[-n:]
return answer
접미사배열
문제설명
어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다.
문자열 my_string이 매개변수로 주어질 때, my_string의 모든 접미사를 사전순으로 정렬한 문자열 배열을 return 하는 solution 함수를 작성해 주세요.
슈도코드
길이만큼 반복문 돌리기... for i in length( ) 해놓고 빈 배열에 추가할 때 [i:] 하기
전체코드
def solution(my_string):
answer = []
for i in range(len(my_string)):
answer.append(my_string[i:])
return sorted(answer)
접미사인지확인하기
문제설명
어떤 문자열에 대해서 접미사는 특정 인덱스부터 시작하는 문자열을 의미합니다. 예를 들어, "banana"의 모든 접미사는 "banana", "anana", "nana", "ana", "na", "a"입니다. 문자열 my_string과 is_suffix가 주어질 때, is_suffix가 my_string의 접미사라면 1을, 아니면 0을 return 하는 solution 함수를 작성해 주세요.
슈도코드
위에 푼 문제에서 비교 하는 함수 하나 더만들기
전체코드
def solution(my_string, is_suffix):
answer = []
for i in range(len(my_string)):
answer.append(my_string[i:])
if is_suffix in answer:
return 1
else:
return 0