반응형
    
    
    
  
                              Notice
                              
                          
                        
                          
                          
                            Recent Posts
                            
                        
                          
                          
                            Recent Comments
                            
                        
                          
                          
                            Link
                            
                        
                    | 일 | 월 | 화 | 수 | 목 | 금 | 토 | 
|---|---|---|---|---|---|---|
| 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 | 31 | 
                            Tags
                            
                        
                          
                          - Nestjs
- 프로그래머스 레벨 2
- javascript
- 백준
- 문자열
- 수학
- 타입 챌린지
- socket
- 알고리즘
- 타입스크립트
- 레벨 1
- 프로그래머스
- HTTP 완벽 가이드
- dfs
- 자바스크립트
- Crawling
- 그래프
- ip
- BFS
- Algorithm
- Node.js
- 소켓
- 크롤링
- typescript
- HTTP
- 쉬운 문제
- TCP
- dp
- type challenge
- 가천대
                            Archives
                            
                        
                          
                          - Today
- Total
kakasoo
[node.js] 점프와 순간 이동 ( 프로그래머스 레벨2 ) 본문
반응형
    
    
    
  // 프로그래머스 레벨2 점프와 순간 이동을 풀었습니다.
const solution = (n) => {
//     const visited = new Array(n + 1).fill(0).map((el, i) => i);
//     const dfs = (cur) => {        
//         for (let i = 1; 2 ** i * cur <= n; i++) {
//             if (visited[cur] < visited[2 ** i * cur]) {
//                 visited[2 ** i * cur] = visited[cur];
//                 dfs(2 ** i * cur);
//             }
//         }
//         if (visited[cur] + 1 < visited[cur + 1]) {
//             visited[cur + 1] = visited[cur] + 1;
//             dfs(cur + 1);
//         }
//     }
//     dfs(1);
//     console.log(visited);
//     return visited[n];
    return Number(n).toString(2).split('').filter((el) => el == 1).length;
}
dfs로 시간 초과가 떠서 bfs로 고치고, 최적화를 위해서 별 짓을 다 했는데도 시간 초과는 사라지지 않았다.
혹시 그래프적인 방법 외에도 뭔가 있나 고민해봤는데, 2로 나눴을 때의 나머지가 1인 횟수가 아무래도 답인 거 같다.
그래서 2진수로 변환하여 구했다.
반응형
    
    
    
  '프로그래밍 > 알고리즘 풀이' 카테고리의 다른 글
| [node.js] n진수 게임 ( 프로그래머스 레벨2 ) (0) | 2021.07.07 | 
|---|---|
| [node.js] 캐시 ( 프로그래머스 레벨2 ) (4) | 2021.07.05 | 
| [node.js] 가장 먼 노드 ( 프로그래머스 레벨3 ) (0) | 2021.07.02 | 
| [node.js] 방문 길이 ( 프로그래머스 레벨2 ) (0) | 2021.07.02 | 
| [node.js] 괄호 회전하기 ( 프로그래머스 레벨2 ) (0) | 2021.07.01 | 
 
                   
                   
                  