문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/12982 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 문제를 보고 처음 든 생각이 그리디 알고리즘 문제라는 것이였다!그리디 알고리즘은 현재 상황에서 당장 좋은 것만 고르는 방법이다. 내 풀이최대한 많은 부서를 지원해줘야 하기 때문에, 작은 예산을 가진 팀들부터 차례대로 지원해서 최대한 많은 부서를 찾으면 된다. 즉, 주어진 d 배열을 오름차순 정렬한 뒤, 각 값을 차례대로 더해, 이 값이 전체 예산보다 작으면 answer을 더하는 식으로 진행..
코딩테스트/PYTHON
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/133502 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 내 풀이 (오답)처음에는 주어진 리스트를 문자열로 바꿔서, 햄버거를 만들 수 있는 문자를 제거하려 했다. # 빵 – 야채 – 고기 - 빵 (1, 2, 3 -> 빵, 야채, 고기)def solution(ingredient): answer = 0 # 햄버거를 만드는 순서는 1 -> 2 -> 3 -> 1 ham = '1231' # 주어진 리스트를 string으로 변경..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/12906 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 내 풀이def solution(arr): # answer의 초기값을 arr의 첫 번째 값으로 answer = [arr[0]] for i in range(len(arr)): # arr 원소와 answer의 직전 값이 같지 않으면 arr 원소 삽입 if arr[i] != answer[-1]: answer.append(arr[i]) ..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/12950 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr '행렬'이라는 단어를 보자마자, numpy가 생각났다. 분명 문제에서 원하는 풀이는 아닐 것 같지만, numpy를 이용하면 행렬 연산을 쉽게 구할 수 있기 때문이다! 첫 번째 풀이import numpy as npdef solution(arr1, arr2): # numpy 배열로 변환 후 계산 a1 = np.array(arr1) a2 = np.array(arr2) ret..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/12934 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 문제에서 주어진대로 구현하면 되는 문제이다. 내 풀이import mathdef solution(n): answer = 0 if math.sqrt(n) == int(math.sqrt(n)): answer = (math.sqrt(n) + 1) ** 2 else: answer = -1 return answer math 라이브러리를 임포트하여, sqr..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/160586 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 이 문제는 풀다가 잘 안되는 부분이 있어서 다른 사람의 풀이를 보고 푼 문제이다. "입출력 예 설명"에 나온대로 구현하면 되는 문제이다. 풀이keymap 안에는 여러 개의 키가 존재한다. 첫 번째 입출력 예에 따라 알아보자면, ABACD는 1번, BCEFD는 2번으로 잡을 수 있다. 이제 ABCD라는 문자열을 만들어보자. 1번 키에서 1번을 눌러 A 작성2번 키에서 1번을 눌러 B 작성..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/155652 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 내 풀이def solution(s, skip, index): answer = '' # 알파벳 리스트 alphabets = ["a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/159994 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 주어진 카드 뭉치들을 사용하여 원하는 단어 배열을 만들 수 있는지 확인하는 문제이다. 내 풀이def solution(cards1, cards2, goal): # c1과 c2는 각 카드뭉치에서 goal에 몇 번 사용했는지 나타냄 c1, c2 = 0, 0 for i in goal: # 만들고자 하는 문장에서의 단어가 어떤 카드 뭉치에 있는지 판단 if..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/140108 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 주어진 문자열을 규칙에 따라 분리하는 문제이다. 내 풀이def solution(s): # 분해한 문자열의 개수 answer = 0 # 문자열을 분해할 수 없을 때까지 반복 while len(s) != 0: yes_x, no_x = 0, 0 # x와 같은 글자 수, x와 다른 글자 수 for i in range(len(s)): ..
문제 설명https://school.programmers.co.kr/learn/courses/30/lessons/142086 프로그래머스코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.programmers.co.kr 문자열을 순회하며, 해당 문자에서 가장 가까운 요소를 찾는 문제이다. 내 풀이def solution(s): # 각 문자의 결과 저장 answer = [] # 문자열을 순회하며 나온 문자 저장 tmp = [] for i in range(len(s)): # 문자가 처음 나왔는지 확인 if s[i] in tmp: ..