일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 |
- sql
- 프로그래머스
- import re
- 코딩테스트
- 코딩
- Level2
- join
- coding
- 코테
- Stack
- coding test
- python
- 시간복잡도
- lv4
- counter
- Queue
- 조합
- mysql
- programmers
- time complexity
- 연습문제
- BFS
- 파이썬
- CodingTest
- collections
- itertools
- lambda
- 데이터분석
- level4
- 완전탐색
- Today
- Total
목록coding test (45)
ror_coding
보통 최대공약수 구하기 하면 Recursion function을 사용하는데 for 문을 통해 쉽게 구하는 코드이다 ! Question 두 수를 입력받아 두 수의 최대공약수와 최소공배수를 반환하는 함수, solution을 완성해 보세요. 배열의 맨 앞에 최대공약수, 그다음 최소공배수를 넣어 반환하면 됩니다. 예를 들어 두 수 3, 12의 최대공약수는 3, 최소공배수는 12이므로 solution(3, 12)는 [3, 12]를 반환해야 합니다. Point NOT recursion functionthe greatest common divisorthe least common multiple 공식 : (n*m) // gcd Code def solution(n, m): gcd = 1 for i ..
numpy array로 변환하여 연산하면 단순 덧셈으로 행렬 간의 덧셈이 가능하다 ! Question 행렬의 덧셈은 행과 열의 크기가 같은 두 행렬의 같은 행, 같은 열의 값을 서로 더한 결과가 됩니다. 2개의 행렬 arr1과 arr2를 입력받아, 행렬 덧셈의 결과를 반환하는 함수, solution을 완성해주세요. Point numpy array 사용이중 for문 사용 Code 1 : numpy 사용 import numpy as npdef solution(arr1, arr2): answer = np.array(arr1)+np.array(arr2) return answer.tolist() Code 2 : 이중 for문 사용 def solution(arr1, arr2): answer =..
isdigit()로 숫자인지 확인 하기 !! 따흑 알던 코드였는데 존재를 잠깐 잊고 있었다..!!그리고 in (4,6) 쓰는게 SQL where 절에서의 활용과 같아서 하나 더 배울 수 있는 좋은 문제다 ㅎㅎ !! Question 문자열 s의 길이가 4 혹은 6이고, 숫자로만 구성돼있는지 확인해주는 함수, solution을 완성하세요. 예를 들어 s가 "a234"이면 False를 리턴하고 "1234"라면 True를 리턴하면 됩니다. Point len(s) in (4,6) 으로 s의 길이가 4 혹은 6인지 판별. [4,6] 도 가능.isdigit() Code def solution(s): return True if len(s) in (4,6) and s.isdigit() else False now ..
EXCEPT 차집합을 사용해서 테이블 간 다른 데이터 출력 하기 ! Question 천재지변으로 인해 일부 데이터가 유실되었습니다. 입양을 간 기록은 있는데, 보호소에 들어온 기록이 없는 동물의 ID와 이름을 ID 순으로 조회하는 SQL문을 작성해주세요. Point EXCEPT 차집합 사용 Code 1 : EXCEPT 차집합 SELECT ANIMAL_ID, NAME FROM ANIMAL_OUTSEXCEPTSELECT ANIMAL_ID, NAME FROM ANIMAL_INS Code 2 : mine SELECT ANIMAL_ID, NAME FROM ANIMAL_OUTS WHERE ANIMAL_ID NOT IN (SELECT ANIMAL_ID FROM ANIMAL_INS) ORDE..
DISTINCT( ) 사용 시 유의점 !SELECT DISTINCT( ) 를 해도 같은 단어가 두 개 나와서 답이 틀렸다.왜 그런지 이유를 찾아보니 distinct는 뒤에 따라 붙는 모든 컬럼들의 중복되는 '조합' 중 하나만 출력한다. Question REST_INFO 테이블에서 음식종류별로 즐겨찾기수가 가장 많은 식당의 음식 종류, ID, 식당 이름, 즐겨찾기수를 조회하는 SQL문을 작성해주세요. 이때 결과는 음식 종류를 기준으로 내림차순 정렬해주세요. Point WHERE 절 서브쿼리SELECT DISTINCT( FOOD_TYPE ) 을 해도 '한식'이 두 개 나옴 -> 따라서 GROUP BY FOOD_TYPE으로 하나만 출력. Code SELECT FOOD_TYPE, REST_ID, REST_..
약수 출력이 아닌 개수만 세고 음/양 결정만 하면 되는 것이기 때문에 숏코드 뿐만 아니라 시간 복잡도, 메모리를 줄일 수 있는 방법이 있다 ! Question 두 정수 left와 right가 매개변수로 주어집니다. left부터 right까지의 모든 수들 중에서, 약수의 개수가 짝수인 수는 더하고, 약수의 개수가 홀수인 수는 뺀 수를 return 하도록 solution 함수를 완성해주세요. Point ( n ** 0.5 ) % 1 로 완전 제곱인지 (약수 홀수) 판별 : Code 1int(n**0.5)==(n**0.5) 로 완전 제곱인지 판별 : Code 2 Code 1 : 완전 제곱 판별( n ** 0.5 ) % 1 def solution(left, right): return sum(n if (..
같은 table을 두 개의 table로 이용하여 JOIN 해서 & (BINARY AND) 연산을 해주었다 !보통 쓰던 코드와는 약간 다른 방식이라 기록하게 되었다 ㅎㅎ ! Question 부모의 형질을 모두 보유한 대장균의 ID(ID), 대장균의 형질(GENOTYPE), 부모 대장균의 형질(PARENT_GENOTYPE)을 출력하는 SQL 문을 작성해주세요. 이때 결과는 ID에 대해 오름차순 정렬해주세요. Point 같은 table을 두 개의 table로 이용하여 JOIN 함.CAST() 를 사용하여 BINARY 값으로 변환. Code SELECT C.ID, C.GENOTYPE, P.GENOTYPE AS PARENT_GENOTYPE FROM ECOLI_DATA P JOIN ECOLI_DATA..
SELECT 절에 MAX() 함수를 사용하면 오류가 생기는 케이스이다.FROM 절에 table 두 개를 쓰고 WHERE 절에서 묶어준다. 이때 FROM 에서 sub query 를 사용한다 !(아직 어색한 코드 순서라 사용하기 어렵긴 하지만 연습하면 유용할 것 같다 !) Question 분화된 연도(YEAR), 분화된 연도별 대장균 크기의 편차(YEAR_DEV), 대장균 개체의 ID(ID) 를 출력하는 SQL 문을 작성해주세요. 분화된 연도별 대장균 크기의 편차는 분화된 연도별 가장 큰 대장균의 크기 - 각 대장균의 크기로 구하며 결과는 연도에 대해 오름차순으로 정렬하고 같은 연도에 대해서는 대장균 크기의 편차에 대해 오름차순으로 정렬해주세요. Point JOIN ON을 쓰지 않고 FROM 에 table..