연권
달콘박스
연권
전체 방문자
56,749
오늘
2
어제
102
  • 전체 (308)
    • Web (22)
      • JavaScript (8)
      • TypeScript (2)
      • Node.js (8)
      • HTML (0)
      • CSS (0)
      • Network (1)
      • Browser (0)
      • Patterns (3)
    • Framwork (4)
      • Vue.js (3)
      • Electron (1)
    • Infra&DevOps (1)
    • Algorithm (246)
    • Database (16)
    • Review (15)
    • Test (4)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

  • 소인수분해 알고리즘 [ javascript ]
    2021.09.08
    소인수분해 알고리즘 [ javascript ]
  • Vue.js에서 infinite scroll 구현하기
    2021.05.27
    Vue.js에서 infinite scroll 구현하기
  • 구름IDE 에서 MySQL 사용하기
    2020.01.09
    구름IDE 에서 MySQL 사용하기
  • JMeter로 REST API 자동 테스트 하기2
    2021.06.24
    JMeter로 REST API 자동 테스트 하기2
  • JMeter로 REST API 자동 테스트 하기1
    2021.06.22
    JMeter로 REST API 자동 테스트 하기1

태그

  • 동적계획법
  • 스택
  • 진수
  • 백트레킹
  • 프로그래머스
  • 백준ㅇ
  • 재귀
  • typescript
  • 정렬
  • java
  • 코딩테스트 연습
  • MySQL
  • 알고리즘
  • javascript
  • DP
  • 문자열
  • sql
  • BFS
  • 진법
  • 백준

최근 댓글

  • 포스팅 잘 보고 가요!
    아이폰 14 pro max
  • 감사합니다 수정하였습니다 :)
    연권
  • mysql.cnf 가 니라 mysqld.cnf 입니다.!!
    ㅇㅇ
  • 안녕하세요. 포스팅 감사합니다.. 저도 Vue-infin⋯
    지돌이
  • 안녕하세요 42서울 재웅시가 가능한가요?
    예나

최근 글

  • Observer Pattern
    2022.06.21
    Observer Pattern
  • Proxy Pattern (JavaScript)
    2022.06.07
    Proxy Pattern (JavaScript)
  • Singleton Pattern (JavaScript)
    2022.06.07
    Singleton Pattern (JavaScript)
  • 타입 좁히기 (Type Guard)
    2022.05.21
    타입 좁히기 (Type Guard)
  • 라인 플러스 면접 후기
    2022.05.13

티스토리

hELLO · Designed By 정상우.
연권

달콘박스

Algorithm

프로그래머스 코딩테스트 연습 Level2 - 점프와 순간 이동 [ Java ]

2021. 4. 21. 11:46
반응형
 

코딩테스트 연습 - 점프와 순간 이동

OO 연구소는 한 번에 K 칸을 앞으로 점프하거나, (현재까지 온 거리) x 2 에 해당하는 위치로 순간이동을 할 수 있는 특수한 기능을 가진 아이언 슈트를 개발하여 판매하고 있습니다. 이 아이언 슈

programmers.co.kr

try 1

dp 문제라고 생각해서 bottom 방식의 dp로 풀었다

n번째 항 = 짝수일 경우 n/2번째 항 홀수일 경우 n/2번째 항 + 1 과 n-1 번째 항중에 작은 값

메모리 초과와 시간초과가 발생했다.

public class Solution {
    public int solution(int n) {
        int d[] = new int[n+1];
        d[0] = 0;
        for (int i = 1; i <= n; i++)
            d[i] = Math.min(d[i-1]+1, i % 2 == 0 ? d[i/2] : d[i/2] + 1);
        return d[n];
    }
}

 

try 2

n이 홀수일때와 짝수일 경우를 나누어 생각했다

public class Solution {
    public int solution(int n) {
        int count = 0;
        
        while (n != 0) {
            if (n % 2 == 0){
                n /= 2;
                continue;
            } else {
                n--;
                count++;
            }
        }
        return count;
    }
}

 

try 3

연산의 결과가 2진법의 1의 개수와 동일하다

public class Solution {
    public int solution(int n) {
        return Integer.bitCount(n);
    }
}
반응형
저작자표시 동일조건
  • 카카오스토리
  • 트위터
  • 페이스북

'Algorithm' 카테고리의 다른 글

백준 12852번 1로 만들기 2 [ Java ]  (0) 2021.04.30
프로그래머스 코딩테스트 연습 Level4 - 우유와 요거트가 담긴 장바구니 [ Mysql ]  (0) 2021.04.23
프로그래머스 코딩테스트 연습 Level2 - 영어 끝말잇기 [ Java ]  (0) 2021.04.21
프로그래머스 코딩테스트 연습 Level1 - 소수 만들기 [ Java ]  (0) 2021.04.20
프로그래머스 코딩테스트 연습 Level1 - 예산 [ Java ]  (0) 2021.04.20
    'Algorithm' 카테고리의 다른 글
    • 백준 12852번 1로 만들기 2 [ Java ]
    • 프로그래머스 코딩테스트 연습 Level4 - 우유와 요거트가 담긴 장바구니 [ Mysql ]
    • 프로그래머스 코딩테스트 연습 Level2 - 영어 끝말잇기 [ Java ]
    • 프로그래머스 코딩테스트 연습 Level1 - 소수 만들기 [ Java ]
    인턴십, 인턴십 코딩테스트, 프로그래머스
    연권
    연권
    댓글쓰기
    다음 글
    프로그래머스 코딩테스트 연습 Level4 - 우유와 요거트가 담긴 장바구니 [ Mysql ]
    이전 글
    프로그래머스 코딩테스트 연습 Level2 - 영어 끝말잇기 [ Java ]

    티스토리툴바