프로그래머스

푼 날짜 : 2024.11.07푼 문제 : 영어 끝말잇기사용한 언어 : python  접근 방식 :1) 이전 단어 끝 문자와 다음 단어 첫 문자가 일치하는지 비교2) 이전에 사용하지 않은 단어여야함 (딕셔너리로 체크)3) n보다 사람번호가 커지면 사람 번호를 다시 첫 번째 번호로 바꾸고 차례 수를 증가   코드 :def solution(n, words): answer = [] myDict = dict() for i in words: myDict[i] = 1 myDict[words[0]] = 0 now = words[0] idx = tern = 1 # idx는 사람번호, tern은 차례 check = False # 끝말잇기가 잘 이어지고 있는지 체..
·Programming/SQL
푼 날짜 : 2024.11.02푼 문제 : 자동차 대여 기록에서 대여중 / 대여 가능 여부 구분하기사용한 언어 : MYSQL 코드 :SELECT CAR_ID, CASE WHEN MAX('2022-10-16' BETWEEN START_DATE AND END_DATE) = 1 THEN '대여중' ELSE '대여 가능' END AS AVAILABILITYFROM CAR_RENTAL_COMPANY_RENTAL_HISTORYGROUP BY CAR_IDORDER BY CAR_ID DESC  풀이 방식 :시작 날짜(START_DATE) 또는 종료 날짜(END_DATE)에 2022-10-16에 포함되어 있어야한다.그리고 그렇다면 '대여 가능' 아니라면 '대여중'을 출력해야한다.SEL..
·Programming/SQL
푼 날짜 : 2024.10.30푼 문제 : 카테고리 별 도서 판매량 집계하기사용한 언어 : MYSQL 코드 :SELECT B.CATEGORY, SUM(S.SALES) as TOTAL_SALESFROM BOOK_SALES as S JOIN BOOK as B ON S.BOOK_ID = B.BOOK_ID # 두 테이블 조인WHERE S.SALES_DATE LIKE "2022-01-%" # 2022-01 판매량을 확인하기 위해GROUP BY B.CATEGORY # 카테고리를 기준으로 그룹화ORDER BY B.CATEGORY # 카테고리 기준 오름차순 정렬  풀이 방식 : 정보가 각각 담겨있는 두 테이블을 조인한다. 이때 공통적으로 가지고 있는 BOOK_ID를 기준으로 조인했다.FROM BOOK_SALES as ..
·Programming/SQL
날짜 비교하는 방법을 정리해보려고 한다! 먼저 BETWEEN A AND B를 사용하는 방법WHERE 날짜 BETWEEN A AND BWHERE 날짜 BETWEEN '2023-01-01' AND '2024-12-31' 또는 부등호를 사용하는 방법WHERE 날짜 >= AWHERE 날짜 >= '2024-10-17 23:59:59' 이런식으로 사용할 수 있다!  적용하기 푼 날짜 : 2024.10.17푼 문제 : 진료과별 총 예약 횟수 출력하기사용한 언어 : MYSQL 코드 :BETWEEN A AND B SELECT MCDP_CD as 진료과코드, COUNT(APNT_YMD) as 오월예약건수FROM APPOINTMENTWHERE APNT_YMD between '2022-05-01 00:00:00' and '2..
·Programming/SQL
SQL 을 풀다보면 문자열을 잘라 사용해야 할 때가 있다.이때 필요한게 바로 SUBSTRING !! SUBSTRING('문자열', 시작위치)SUBSTRING('문자열', 시작위치, 몇 개나 가져올지)  예를 들어 문자열 : "HAPPY"SUBSTRING(HAPPY, 1, 2) 하고 한다면,결과는 HA 가 된다. 적용하기 푼 날짜 : 2024.10.17푼 문제 : 카테고리 별 상품 개수 구하기사용한 언어 : MYSQL 코드 :SELECT SUBSTRING(PRODUCT_CODE, 1, 2) as CATEGORY, COUNT(PRODUCT_CODE) as PRODUCTSFROM PRODUCTGROUP BY SUBSTRING(PRODUCT_CODE, 1, 2)
·Programming/SQL
SQL을 사용하다보면 종종 기존의 컬럼명이 아닌 별칭을 사용하게 되는 경우가 발생한다. 따라서, SQL에서 보통 컬럼 별칭을 사용할 때에는 as를 사용한다.SELECT 컬럼명 as 컬럼별칭 위와 같은 형태로 작성할 수 있다.  예시로, 학생들 중 가장 큰 키(HEIGHT)를 가진 학생의 키를 MAX_HEIGHT로 출력한다고 가정하자.다음과 같이 작성할 수 있다.SELECT MAX(HEIGHT) as MAX_HEIGHTFROM STUDENT 이렇게 HEIGHT 라는 컬럼명을 MAX_HEIGHT로 바꾸어 출력할 수 있다.  그렇다면 값에 다른 문자열을 추가할 때는 어떻게 하면 좋을까 ?답은 concat을 사용하는 것이다. 형태는 다음과 같다.SELECT concat('str1', 'str2', 'str3' ..
푼 날짜 : 2024.04.30푼 문제 : [연습문제] / 추억점수사용한 언어 : javascript  파라미터 설명 : name그리워하는 사람의 이름을 담은 문자열 배열yearning각 사람별 그리움 점수를 담은 정수 배열photo각 사진에 찍힌 인물의 이름을 담은 이차원 문자열 배열  전체 코드 : function solution(name, yearning, photo) { var answer = []; const myMap = new Map(); name.forEach((user, idx)=> { myMap.set(user, yearning[idx]); }) photo.forEach((item) => { let score = 0; ..
푼 날짜 : 2024.04.30푼 문제 : [연습문제] / 달리기 경주사용한 언어 : javascript  파라미터 설명 : players선수들의 이름이 1등부터 현재 등수 순서대로 담긴 문자열 배열callings해설진이 부른 이름을 담은 문자열 배열  전체 코드 :  function solution(players, callings) { const myMap = new Map(); players.forEach((item, idx) => { myMap.set(item, idx); }) callings.forEach((item, idx2) => { let idx = myMap.get(item); let temp = players[idx..
__narrrrrmm
'프로그래머스' 태그의 글 목록