목록분류 전체보기 (271)
DHistory
문제 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 DAY = 28 def solution(today, terms, privacies): answer = [] # 현재 날짜를 일로 변경 currentDays = calcuateToDays(today) # 각 약관 종류 별 만료일자 expiredDays = {} for term in terms: termType, expirationPeriod = term.split() expiredDays[termType] = int(expirationPeriod) * DAY # 각 개인정보 수집 일자 만료 확인 fo..
문제 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 def solution(s, skip, index): # 초기화 answer = '' for alpha in s: origin = ord(alpha) # index까지 한 칸 씩 이동 for _ in range(1, index + 1): origin += 1 # z를 넘어가면 a로 다시 돌아오는 조건 if origin > ord('z'): origin -= 26 # skip 문자열이 포함되는 경우 한 칸 이동 while chr(origin) in skip: origin += 1 # z를 넘어가면 a..
11-3-2 MySQL 연산자 Equal = 기호를 사용하여 비교를 수행합니다. 연산자는 = 연산자와 비슷하지만 NULL 값에 대한 비교까지 수행합니다. Not Equal 결과를 반대로 만드는 연산자로 NOT을 사용합니다. ! 연산자를 사용할 수도 있습니다. REGEXP 문자열 값이 어떤 패턴을 만족하는지 확인하는 연산자입니다. RLIKE와 동일하게 수행하는 연산자입니다. 문자열을 하나하나 분리하여 조합하기 때문에 index를 사용할 수 없습니다. LIKE REGEXP 연산자보다는 훨씬 단순한 문자열 패턴 비교 연산자입니다. DBMS엣는 LIKE 연산자를 더 많이 사용합니다. LIKE 연산자는 정규 표현식을 검사하는 것이 아닌 어떤 상수 문자열이 있는지 없는지 정도를 판단하는 연산자입니다. LIKE에서 ..
기본적인 연산자는 MySQL에서도 거의 비슷하게 사용하지만 MySQL만 사용하는 연산자나 표기법이 있습니다. ANSI 표준 형태가 아닌 연산자가 많이 있습니다. 가능하면 SQL의 가독성을 높이기 위해 ANSI 표준 형태의 연산자를 사용하길 권장합니다. 11-3-1 리터펄 표기법 문자열 문자열 SQL 홑따옴표 (') MySQL 홑따옴표 (') / 쌍따옴표 (") SELECT * FROM departments WHERE dept_no='d0001'; SELECT * FROM departments WHERE dept_no="d0001"; SQL 표준에서는 문자열 값에 홑따옴표가 포함돼 있을 때 홑따옴표를 두 번 연속해서 입력하면 됩니다. MySQL에서는 쌍따옴표와 홑따옴표를 혼합해서 이런 문제를 피해 가기도 ..
MySQL 매뉴얼에 명시된 SQL 문법은 사용할 수 있는 모든 키워드나 기능을 하나의 문장에 다 표기해뒀기 때문에 한눈에 이해되지 않는다는 단점이 있습니다. 하지만 해당 버전에 맞는 SQL 문법을 참조하기에는 매뉴얼만큼 정확한 자료가 없습니다. INSERT [LOW_PRIORITY | DELAYED | HIGH_PRIORITY] [IGNORE] [INTO] tabl_name [PARTITION (partition_name [, partition_name] ...)] [(col_name [, col_name] ...)] {VALUES | VALUE} (value_list) [, (value_list)] ... [ON DUPLICATE KEY UPDATE assignment_list] 대괄호 [] 선택 사항..
문제 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 def solution(cards1, cards2, goal): # 초기화 i = 0 j = 0 k = 0 # 문제 풀이 while True: # 종료 조건 1: Goal 완성 시 종료 if k >= len(goal): return "Yes" current = goal[k] # 종료 조건 2: goal에 해당하는 card가 없는 경우 종료 if cards1[i] != current and cards2[j] != current: return "No" if i < len(cards1) - 1 and c..
문제 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 def solution(keymap, targets): # 초기화 answer = [] letters = [0] * 26 # 문제 풀이 # 각 문자별 최소 자판 횟수 for key in keymap: for i in range(len(key)): index = ord(key[i]) - ord('A') if letters[index] == 0 or letters[index] > i + 1: letters[index] = i + 1 # target을 완성하기 위한 최소 자판 횟수 for target i..
문제 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 def solution(n, m, section): # 초기화 result = 0 array = [False] * (n) for i in section: array[i - 1] = True # 문제 풀이 index = 0 while index < n: if array[index]: result += 1 index += m else: index += 1 return result 채점 결과
문제 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 def solution(wallpaper): # 초기화 n, m = len(wallpaper), len(wallpaper[0]) map = [list(row) for row in wallpaper] x = [] y = [] # 문제풀이 for i in range(n): for j in range(m): if map[i][j] == '#': x.append(i) y.append(j) return [min(x), min(y), max(x) + 1, max(y) + 1] 채점 결과
문제 프로그래머스 코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요. programmers.co.kr 풀이 directions = { 'N': (-1, 0), 'W': (0, -1), 'S': (1, 0), 'E': (0, 1) } def solution(park, routes): # 초기화 n, m = len(park), len(park[0]) x, y = 0, 0 maps = [] for i in range(n): temp = [] for j in range(m): if park[i][j] == 'S': x, y = (i, j) temp.append(park[i][j]) maps.append(temp..