[코딩테스트 입문]Day12
모음 제거
문제 설명
영어에선 a, e, i, o, u 다섯 가지 알파벳을 모음으로 분류합니다. 문자열 my_string이 매개변수로 주어질 때 모음을 제거한 문자열을 return하도록 solution 함수를 완성해주세요.
제한사항
my_string은 소문자와 공백으로 이루어져 있습니다.- 1 ≤
my_string의 길이 ≤ 1,000
입출력 예
| my_string | result |
|---|---|
| “bus” | “bs” |
| “nice to meet you” | “nc t mt y” |
문제풀이
def solution(my_string):
answer = ''
for i in my_string:
if i not in ['a','e','i', 'o', 'u']:
answer += i
return answer
def solution(my_string):
return "".join([i for i in my_string if not(i in "aeiou")])
문자열 정렬하기(1)
문제 설명
문자열 my_string이 매개변수로 주어질 때, my_string 안에 있는 숫자만 골라 오름차순 정렬한 리스트를 return 하도록 solution 함수를 작성해보세요.
제한사항
- 1 ≤
my_string의 길이 ≤ 100 my_string에는 숫자가 한 개 이상 포함되어 있습니다.my_string은 영어 소문자 또는 0부터 9까지의 숫자로 이루어져 있습니다. - - -
입출력 예
| my_string | result |
|---|---|
| “hi12392” | [1, 2, 2, 3, 9] |
| “p2o4i8gj2” | [2, 2, 4, 8] |
| “abcde0” | [0] |
문제풀이
def solution(my_string):
answer = []
for i in my_string:
if i.isdigit():
answer.append(int(i))
return sorted(answer)
isdigit()
string 클래스에 있는 매서드로 문자열.isdigit() 형식으로 사용합니다.
문자열에 있는 0을 포함한 양수형 정수를 판별 합니다. 음수나 소숫점을 포함한 수는 문자로 판단합니다.
def solution(my_string):
return sorted([int(c) for c in my_string if c.isdigit()])
숨어있는 숫자의 덧셈(1)
문제 설명
문자열 my_string이 매개변수로 주어집니다. my_string안의 모든 자연수들의 합을 return하도록 solution 함수를 완성해주세요.
제한사항
- 1 ≤
my_string의 길이 ≤ 1,000 my_string은 소문자, 대문자 그리고 한자리 자연수로만 구성되어있습니다.
입출력 예
| my_string | result |
|---|---|
| “aAb1B2cC34oOp” | 10 |
| “1a2b3c4d123” | 16 |
문제풀이
def solution(my_string):
return sum([int(i) for i in my_string if i.isdigit()])
소인수분해
문제 설명
소인수분해란 어떤 수를 소수들의 곱으로 표현하는 것입니다. 예를 들어 12를 소인수 분해하면 2 * 2 * 3 으로 나타낼 수 있습니다. 따라서 12의 소인수는 2와 3입니다. 자연수 n이 매개변수로 주어질 때 n의 소인수를 오름차순으로 담은 배열을 return하도록 solution 함수를 완성해주세요.
제한사항
- 2 ≤
n≤ 10,000
입출력 예
| n | result |
|---|---|
| 12 | [2, 3] |
| 17 | [17] |
| 420 | [2, 3, 5, 7] |
문제풀이
def solution(n):
answer = []
num = 2
while num <= n:
if n % num == 0:
if num not in answer:
answer.append(num)
n = n//num
else:
num += 1
return sorted(answer)
댓글남기기