목록분류 전체보기 (493)
규도자 개발 블로그
[프로그래머스/Level1/파이썬3(python3)] 제일 작은 수 제거하기 문제 정수를 저장한 배열, arr 에서 가장 작은 수를 제거한 배열을 리턴하는 함수, solution을 완성해주세요. 단, 리턴하려는 배열이 빈 배열인 경우엔 배열에 -1을 채워 리턴하세요. 예를들어 arr이 [4,3,2,1]인 경우는 [4,3,2]를 리턴 하고, [10]면 [-1]을 리턴 합니다. 제한사항 arr은 길이 1 이상인 배열입니다. 인덱스 i, j에 대해 i ≠ j이면 arr[i] ≠ arr[j] 입니다. 입출력 예 arrreturn [4,3,2,1][4,3,2][10][-1] 풀이 def solution(arr): if len(arr) > 1 and min(arr): del arr[arr.index(min(arr)..
[프로그래머스/Level1/파이썬3(python3)] 정수 제곱근 판별 문제 임의의 양의 정수 n에 대해, n이 어떤 양의 정수 x의 제곱인지 아닌지 판단하려 합니다. n이 양의 정수 x의 제곱이라면 x+1의 제곱을 리턴하고, n이 양의 정수 x의 제곱이 아니라면 -1을 리턴하는 함수를 완성하세요. 제한사항 n은 1이상, 50000000000000 이하인 양의 정수입니다. 입출력 예 nreturn 1211443-1 입출력 예 설명 입출력 예#1 121은 양의 정수 11의 제곱이므로, (11+1)를 제곱한 144를 리턴합니다. 입출력 예#2 3은 양의 정수의 제곱이 아니므로, -1을 리턴합니다. 풀이 def solution(n): return int(((n ** 0.5) + 1)) ** 2 if (n **..
[프로그래머스/Level1/파이썬3(python3)] 정수 내림차순으로 배치하기 문제 함수 solution은 정수 n을 매개변수로 입력받습니다. n의 각 자릿수를 큰것부터 작은 순으로 정렬한 새로운 정수를 리턴해주세요. 예를들어 n이 118372면 873211을 리턴하면 됩니다. 제한사항 n은 1이상 8000000000 이하인 자연수입니다. 입출력 예 nreturn 118372873211 풀이 def solution(n): return int(''.join(sorted(str(n), reverse=True))) 설명 파이썬에서 어떠한 자료를 특정 기준으로 정렬하고싶다고 한다면 일단 리스트화하는 걸 생각하면 편리하게 응용할 수 있다. 파이썬은 문자열을 리스트형태로 다루기 때문에 str로 주어진 정수를 형변..
[프로그래머스/Level1/파이썬3(python3)] 자연수 뒤집어 배열로 만들기 문제 자연수 n을 뒤집어 각 자리 숫자를 원소로 가지는 배열 형태로 리턴해주세요. 예를들어 n이 12345이면 [5,4,3,2,1]을 리턴합니다. 제한사항 n은 10,000,000,000이하인 자연수입니다. 입출력 예 nreturn 12345[5,4,3,2,1] 풀이 def solution(n): return list(map(int, reversed(str(n)))) 설명 reversed는 iterable한 자료형을 뒤집어서 리턴해주는 함수이다. 파이썬에서 기본 자료형을 다뤄본 사람들은 알다시피 문자열을 배열처럼 다룰 수 있으므로 먼저 str()을 통해 형변환, 그리고 reversed를 통해 반대로 배치해준 다음에 map함..
[프로그래머스/Level1/파이썬3(python3)] 문자열 내림차순으로 배치하기 문제 문자열 s에 나타나는 문자를 큰것부터 작은 순으로 정렬해 새로운 문자열을 리턴하는 함수, solution을 완성해주세요. s는 영문 대소문자로만 구성되어 있으며, 대문자는 소문자보다 작은 것으로 간주합니다. 제한사항 str은 길이 1 이상인 문자열입니다. 입출력 예 sreturn "Zbcdefg""gfedcbZ" 풀이 def solution(s): return ''.join(sorted(s, reverse=True)) 설명 sorted는 list를 반환하기 때문에 위와 같은 형태로 문자열로 변환하여 문제를 해결하였다.
.gg도메인 이야기 good game이라는 말이 있다. 게이머들에겐 익숙하겠지만 일반인들은 그냥 "좋은 게임?"정도로 인식할 수 있을 것 같다. 직역하자면 좋은 게임도 맞는 말이지만 이 말이 주로 쓰이는 상황은 게임에서 상대에게 패배했을 때, 혹은 시작하기 전에 인사할 때이다. 그러니까 게임에서 패배가 확정된 사람이 "좋은 게임 했습니다"하면서 물러나는 의미이거나, 시작하기 전에 "좋은 게임 합시다"하는 의미로 쓰인다. 어떻게 보면 GG는 사람과 사람끼리 대결하는 게임에 있어서 가장 유명한 멘트라고도 할 수 있다. 그 대표성과 인지도 만큼이나 게임 관련 사이트들이 gg도메인을 달고 나오는 경우가 굉장히 많이 생겼는데 대표적으로 op.gg를 들 수 있다. 근데 gg는 어디서 튀어나온 애일까? gg는 최상위..
마이크 어만트라우와 손녀 케일리 궁금해서 레딧에서 찾아봤는데 어느 나사빠진 외국인이 마이크가 총쏘고 다녀서 poppop이라고 하는 거라고 확신을 하는 거다. 아무리 생각해봐도 이건 아닌 것 같아서 그냥 궁금한채로 살고 있었는데 마이크의 딸이 마이크에게 pop이라고 부르는 데서 확신을 가졌다. poppop은 아빠의 아빠라는 뜻이다. 그러니까 Father(아버지)를 보통 papa(아빠)라고 부르는데 이걸 또 줄여서 pop이라고 부르는 거였다. 굳이 한국말로 하자면 빠...? 가 되려나. 케일리는 엄마가 아빠를 pop이라 부르는 걸 보고 배워서 poppop이라고 한 게 아닐까 싶다.
[프로그래머스/Level1/파이썬3(python3)] 문자열 내 마음대로 정렬하기 문제 문자열로 구성된 리스트 strings와, 정수 n이 주어졌을 때, 각 문자열의 인덱스 n번째 글자를 기준으로 오름차순 정렬하려 합니다. 예를 들어 strings가 ["sun", "bed", "car"]이고 n이 1이면 각 단어의 인덱스 1의 문자 "u", "e", "a"로 strings를 정렬합니다. 제한사항 strings는 길이 1 이상, 50이하인 배열입니다. strings의 원소는 소문자 알파벳으로 이루어져 있습니다. strings의 원소는 길이 1 이상, 100이하인 문자열입니다. 모든 strings의 원소의 길이는 n보다 큽니다. 인덱스 1의 문자가 같은 문자열이 여럿 일 경우, 사전순으로 앞선 문자열이 앞쪽..
[프로그래머스/Level1/파이썬3(python3)] 체육복 문제 점심시간에 도둑이 들어, 일부 학생이 체육복을 도난당했습니다. 다행히 여벌 체육복이 있는 학생이 이들에게 체육복을 빌려주려 합니다. 학생들의 번호는 체격 순으로 매겨져 있어, 바로 앞번호의 학생이나 바로 뒷번호의 학생에게만 체육복을 빌려줄 수 있습니다. 예를 들어, 4번 학생은 3번 학생이나 5번 학생에게만 체육복을 빌려줄 수 있습니다. 체육복이 없으면 수업을 들을 수 없기 때문에 체육복을 적절히 빌려 최대한 많은 학생이 체육수업을 들어야 합니다. 전체 학생의 수 n, 체육복을 도난당한 학생들의 번호가 담긴 배열 lost, 여벌의 체육복을 가져온 학생들의 번호가 담긴 배열 reserve가 매개변수로 주어질 때, 체육수업을 들을 수 있는 학..
[프로그래머스/Level1/파이썬3(python3)] 실패율 (2019 KAKAO BLIND RECRUITMENT) 문제 슈퍼 게임 개발자 오렐리는 큰 고민에 빠졌다. 그녀가 만든 프랜즈 오천성이 대성공을 거뒀지만, 요즘 신규 사용자의 수가 급감한 것이다. 원인은 신규 사용자와 기존 사용자 사이에 스테이지 차이가 너무 큰 것이 문제였다. 이 문제를 어떻게 할까 고민 한 그녀는 동적으로 게임 시간을 늘려서 난이도를 조절하기로 했다. 역시 슈퍼 개발자라 대부분의 로직은 쉽게 구현했지만, 실패율을 구하는 부분에서 위기에 빠지고 말았다. 오렐리를 위해 실패율을 구하는 코드를 완성하라. 실패율은 다음과 같이 정의한다. 스테이지에 도달했으나 아직 클리어하지 못한 플레이어의 수 / 스테이지에 도달한 플레이어 수 전체..