일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 | 29 | 30 |
- 그리디
- 해쉬
- 슬라이딩윈도우
- 큐
- 스택
- NextAuth
- next.js
- cookie
- 정렬
- 투포인터
- 라이프사이클
- TypeScript
- react-query
- textarea autosize
- 블로그만들기
- react
- isNaN
- aws lightsail
- never타입
- 빅오
- nestjs
- tailwindcss
- typscript
- nextjs
- 버블정렬
- styled-components
- js알고리즘
- Algorithm
- JavaScript
- 알고리즘
- Today
- Total
목록js알고리즘 (40)
far

두 수를 입력받아 두 수의 최대공약수와 최소공배수를 반환하는 함수, solution을 완성해 보세요. 배열의 맨 앞에 최대공약수, 그다음 최소공배수를 넣어 반환하면 됩니다. 예를 들어 두 수 3, 12의 최대공약수는 3, 최소공배수는 12이므로 solution(3, 12)는 [3, 12]를 반환해야 합니다. 제한 사항 두 수는 1이상 1000000이하의 자연수입니다. 입출력 예 1 n = 3, m = 12 return [3, 12] 입출력 예 2 n = 2, m = 5 return [1, 10] 나의 풀이 function solution(n, m) { let answer = []; const Min = (x) => { if (x > n) { return; } else { if (m % x === 0 &&..
결혼식 현수는 다음 달에 결혼을 합니다. 현수는 결혼식 피로연을 장소를 빌려 3일간 쉬지 않고 하려고 합니다. 피로연에 참석하는 친구들 N명의 참석하는 시간정보를 현수는 친구들에게 미리 요구했습니다. 각 친구들은 자신이 몇 시에 도착해서 몇 시에 떠날 것인지 현수에게 알려주었습니다. 현수는 이 정보를 바탕으로 피로연 장소에 동시에 존재하는 최대 인원수를 구하여 그 인원을 수용할 수 있는 장소를 빌리려고 합니다. 여러분이 현수를 도와주세요. 만약 한 친구가 오는 시간 13, 가는시간 15라면 이 친구는 13시 정각에 피로연 장에 존재하는 것이고 15시 정각에는 존재하지 않는다고 가정합니다. 입력설명 첫째 줄에 피로연에 참석할 인원수 N(5= tmp1 && wedding[j][0] < tmp2) { cnt+..
회의실 배정 한 개의 회의실이 있는데 이를 사용하고자 하는 n개의 회의들에 대하여 회의실 사용표를 만들려고 한다. 각 회의에 대해 시작시간과 끝나는 시간이 주어져 있고, 각 회의가 겹치지 않게 하면서 회의실을 사용할 수 있는 최대수의 회의를 찾아라. 단, 회의는 한번 시작하면 중간에 중단될 수 없으며 한 회의가 끝나는 것과 동시에 다음 회의가 시작될 수 있다. 입력설명 첫째 줄에 회의의 수 n(1{ if(a[1]===b[1]) return a[0]-b[0]; else return a[1]-b[1]; }) let et=0; for(let x of meeting){ if(x[0]>=et){ answer++; et=x[1]; } } return answer; } let arr=[[1, 4], [2, 3], [..
좌표 정렬 N개의 평면상의 좌표(x, y)가 주어지면 모든 좌표를 오름차순으로 정렬하는 프로그램을 작성하세요. 정렬기준은 먼저 x값의 의해서 정렬하고, x값이 같을 경우 y값에 의해 정렬합니다. 입력설명 첫째 줄에 좌표의 개수인 N(3
장난꾸러기 현수 새 학기가 시작되었습니다. 현수는 새 짝꿍을 만나 너무 신이 났습니다. 현수네 반에는 N명의 학생들이 있습니다. 선생님은 반 학생들에게 반 번호를 정해 주기 위해 운동장에 반 학생들을 키가 가장 작은 학생부터 일렬로 키순으로 세웠습니다. 제일 앞에 가장 작은 학생부터 반 번호를 1번부터 N번까지 부여합니다. 현수는 짝꿍보다 키가 큽니다. 그런데 현수가 앞 번호를 받고 싶어 짝꿍과 자리를 바꿨습니다. 선생님은 이 사실을 모르고 학생들에게 서있는 순서대로 번호를 부여했습니다. 현수와 짝꿍이 자리를 바꾼 반 학생들의 일렬로 서있는 키 정보가 주어질 때 현수가 받은 번호와 현수 짝꿍이 받은 번호를 차례로 출력하는 프로그램을 작성하세요. 입력설명 첫 번째 줄에 자연수 N(5
Least Recently Used 캐시메모리는 CPU와 주기억장치(DRAM) 사이의 고속의 임시 메모리로서 CPU가 처리할 작업을 저장해 놓았다가 필요할 바로 사용해서 처리속도를 높이는 장치이다. 워낙 비싸고 용량이 작아 효율적으로 사용해야 한다. 철수의 컴퓨터는 캐시메모리 사용 규칙이 LRU 알고리즘을 따른다. LRU 알고리즘은 Least Recently Used 의 약자로 직역하자면 가장 최근에 사용되지 않은 것 정도의 의미를 가지고 있습니다. 캐시에서 작업을 제거할 때 가장 오랫동안 사용하지 않은 것을 제거하겠다는 알고리즘입니다. 만약 캐시의 사이즈가 5이고 작업이 | 2 | 3 | 1 | 6 | 7 | 순으로 저장되어 있다면, (맨 앞이 가장 최근에 쓰인 작업이고, 맨 뒤는 가장 오랫동안 쓰이지..
삽입 정렬 N개의 숫자가 입력되면 오름차순으로 정렬하여 출력하는 프로그램을 작성하세요. 정렬하는 방법은 삽입정렬입니다. 입력설명 첫 번째 줄에 자연수 N(1 tmp) { arr[j+1] = arr[j]; } else { break } } arr[j+1] = tmp } return answer; } let arr=[11, 7, 5, 6, 10, 9]; console.log(solution(arr)); 삽입 정렬이란 배열의 요소를 차례대로 이미 정렬된 배열과 비교해 올바른 위치를 찾아 삽입하는 방법이다. i가 커질 때 마다 j는 뒤에서부터 배열을 검사한다. 그리고 arr[j]가 tmp보다 크다면 순서가 잘못됐다는 얘기니까 arr[j+1]자리에 arr[j]를 삽입한다. 이걸 반복문이 끝날 때 까지 진행한다. ..
Special Sort N개의 정수가 입력되면 당신은 입력된 값을 정렬해야 한다. 음의 정수는 앞쪽에 양의정수는 뒷쪽에 있어야 한다. 또한 양의정수와 음의정수의 순서에는 변함이 없어야 한다. 입력설명 첫 번째 줄에 정수 N(5
버블 정렬 N개의 숫자가 입력되면 오름차순으로 정렬하여 출력하는 프로그램을 작성하세요. 정렬하는 방법은 버블정렬입니다. 입력설명 첫 번째 줄에 자연수 N(1