[문제]0과 1로 이루어진 어떤 문자열 x에 대한 이진 변환을 다음과 같이 정의합니다. x의 모든 0을 제거합니다. x의 길이를 c라고 하면, x를 "c를 2진법으로 표현한 문자열"로 바꿉니다. 예를 들어, x = "0111010"이라면, x에 이진 변환을 가하면 x = "0111010" -> "1111" -> "100" 이 됩니다. 0과 1로 이루어진 문자열 s가 매개변수로 주어집니다. s가 "1"이 될 때까지 계속해서 s에 이진 변환을 가했을 때, 이진 변환의 횟수와 변환 과정에서 제거된 모든 0의 개수를 각각 배열에 담아 return 하도록 solution 함수를 완성해주세요. [풀이]def solution(s): count, zero = 0, 0 while s != '1': ..
전체 글
[문제]배열 arr가 주어집니다. 배열 arr의 각 원소는 숫자 0부터 9까지로 이루어져 있습니다. 이때, 배열 arr에서 연속적으로 나타나는 숫자는 하나만 남기고 전부 제거하려고 합니다. 단, 제거된 후 남은 수들을 반환할 때는 배열 arr의 원소들의 순서를 유지해야 합니다. 예를 들면, arr = [1, 1, 3, 3, 0, 1, 1] 이면 [1, 3, 0, 1] 을 return 합니다. arr = [4, 4, 4, 3, 3] 이면 [4, 3] 을 return 합니다. 배열 arr에서 연속적으로 나타나는 숫자는 제거하고 남은 수들을 return 하는 solution 함수를 완성해 주세요. [풀이]def solution(arr): stack = [] for i in range(len(..
[문제]JadenCase란 모든 단어의 첫 문자가 대문자이고, 그 외의 알파벳은 소문자인 문자열입니다. 단, 첫 문자가 알파벳이 아닐 때에는 이어지는 알파벳은 소문자로 쓰면 됩니다.문자열 s가 주어졌을 때, s를 JadenCase로 바꾼 문자열을 리턴하는 함수, solution을 완성해주세요. [풀이]def solution(s): answer = '' s=s.split(' ') for i in range(len(s)): s[i]=s[i].capitalize() answer=' '.join(s) return answer s.split(' ')공백을 기준으로 나눠준다, 만약에 ',' 를 쓰면 ,를 기준으로 나누고 리스트로 반환한다. for i in range(len(s..
[문제]길이가 같은 배열 A, B 두개가 있습니다. 각 배열은 자연수로 이루어져 있습니다. 배열 A, B에서 각각 한 개의 숫자를 뽑아 두 수를 곱합니다. 이러한 과정을 배열의 길이만큼 반복하며, 두 수를 곱한 값을 누적하여 더합니다. 이때 최종적으로 누적된 값이 최소가 되도록 만드는 것이 목표입니다.(단, 각 배열에서 k번째 숫자를 뽑았다면 다음에 k번째 숫자는 다시 뽑을 수 없습니다.) [풀이]def solution(A,B): answer = 0 A.sort(reverse=True) B.sort() for i in range(len(A)): answer += (A[i]*B[i]) return answer 양 쪽 배열을 곱해서 최솟값이 나오려면 A 배열은 내림차순..
[문제]괄호가 바르게 짝지어졌다는 것은 '(' 문자로 열렸으면 반드시 짝지어서 ')' 문자로 닫혀야 한다는 뜻입니다. "()()" 또는 "(())()" 는 올바른 괄호입니다. ")()(" 또는 "(()(" 는 올바르지 않은 괄호입니다. '(' 또는 ')' 로만 이루어진 문자열 s가 주어졌을 때, 문자열 s가 올바른 괄호이면 true를 return 하고, 올바르지 않은 괄호이면 false를 return 하는 solution 함수를 완성해 주세요. [풀이]def solution(s): stack = [] for i in s: if i == "(": stack.append(i) else: if stack == []: ..
[문제]문자열 s에는 공백으로 구분된 숫자들이 저장되어 있습니다. str에 나타나는 숫자 중 최소값과 최대값을 찾아 이를 "(최소값) (최대값)"형태의 문자열을 반환하는 함수, solution을 완성하세요. 예를들어 s가 "1 2 3 4"라면 "1 4"를 리턴하고, "-1 -2 -3 -4"라면 "-4 -1"을 리턴하면 됩니다. [풀이]def solution(s): numbers = list(map(int, s.split())) min_num = min(numbers) max_num = max(numbers) return f"{min_num} {max_num}"s.split()를 통해서 s 라는 문자열의 공백을 기준으로 각 문자를 정수형으로 변환해준다.변환 된 숫자를 가지고 최..
python3가 안되면 python으로 하면되고 가상환경에 원하는 이름을 넣어주면 된다.python3 -m venv 가상환경 이름python -m venv 가상환경 이름 'sample' 이라는 가상환경을 만들고 실행시키는 방법이다.# 가상환경 생성python -m venv sample# 가상환경 실행./sample/Scripts/activate
[문제]문자열 s의 길이가 4 혹은 6이고, 숫자로만 구성돼있는지 확인해주는 함수, solution을 완성하세요. 예를 들어 s가 "a234"이면 False를 리턴하고 "1234"라면 True를 리턴하면 됩니다. [풀이]def solution(s): if len(s) == 4 or len(s) == 6: if s.isdigit(): return True else: return False else: return False 먼저 문자열의 길이가 4 또는 6인지로 걸러주고, isdigit()를 사용해서 숫자만 있는지 판단했다. str.isdigit() : 문자열이 숫자로만 이루어져 있는지 확인해준다.str. isalpha(..