34일차 - 알고리즘 코드카타

2024. 8. 30. 09:45·Java & Spring/코딩테스트

- 회고

80. 예상 대진표 : https://school.programmers.co.kr/learn/courses/30/lessons/12985

 

프로그래머스

코드 중심의 개발자 채용. 스택 기반의 포지션 매칭. 프로그래머스의 개발자 맞춤형 프로필을 등록하고, 나와 기술 궁합이 잘 맞는 기업들을 매칭 받으세요.

programmers.co.kr

- 풀이 과정

class Solution{
    public int solution(int n, int a, int b){
        int s = 1;
        int answer = 0; 

        for(int i = 1; s != n; i++){
            s = (int)Math.pow(2, i);
            if(a % 2 != 0){
                if(a + 1 == b){
                    answer = i;
                    break;
                }
            }else{
                if(a - 1 == b){
                    answer = i;
                    break;
                }
            }
            if(a % 2 != 0){
                a++;
                a /= 2;
            }else {
                a /= 2;
            }

            if(b % 2 != 0){
                b++;
                b /= 2;
            }else {
                b /= 2;
            }

        }
        return answer;
    }
}
  1. 라운드를 Math.pow를 통해 계산하며 for문을 진행한다.
  2. a가 홀수일 경우 +1이 b이면 만나는 경우이고
  3. a가 짝수일 경우 -1이 b이면 만나는 경우이다.
  4. 해당 경우의 i가 몇번째 만나는지에 대한 답이다.
  5. a,b는 홀수일 경우 1을 더한 후 나누기 2로 초기화
  6. 짝수일 경우 나누기 2로 초기화한다.

- 회고

코드가 너무 세로로 길어진 느낌이 든다. 개선 할 수 있다고 생각된다.

class Solution{
    public int solution(int n, int a, int b){
        int round = 0;

        while(a != b){
            a = (a + 1) / 2;
            b = (b + 1) / 2;
            round++;
        }

        return round;
    }
}
  1. 두사람이 만나는 경우는 +1을 2로 나눈 몫이 같은 경우이다.
  2. 그러므로 위와같이 개선 할 수 있다.

- 진행

일자 완료 번호
24.07.16 ~ 24.07.31 1~63
24.08.01 ~ 24.08.20 64~75
24.08.21 76
24.08.23 77
24.08.27 78
24.08.29 79
24.08.30 80
   
   
   
   
 

'Java & Spring > 코딩테스트' 카테고리의 다른 글

42일차 - 알고리즘 코드카타  (2) 2024.09.11
39일차 - 알고리즘 코드카타  (1) 2024.09.06
33일차 - 알고리즘 코드카타  (1) 2024.08.30
31일차 - 알고리즘 코드카타  (0) 2024.08.27
29일차 - 알고리즘 코드카타  (0) 2024.08.23
'Java & Spring/코딩테스트' 카테고리의 다른 글
  • 42일차 - 알고리즘 코드카타
  • 39일차 - 알고리즘 코드카타
  • 33일차 - 알고리즘 코드카타
  • 31일차 - 알고리즘 코드카타
DJ.Kang
DJ.Kang
백엔드 개발 기록 블로그
  • DJ.Kang
    DJ Hello World
    DJ.Kang
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 이론공부
        • 자격증
        • 개념
      • 시스템설계
      • Java & Spring
        • TIL
        • 트러블슈팅
        • 고도화
        • 알고리즘
        • 코딩테스트
        • Java
        • Spring
        • Thymeleaf
      • 프로젝트
        • coin-trading
        • 트러블슈팅
      • Docker
      • DB
      • AWS
      • CI-CD
      • 웹
      • git & github
      • 구인공고분석
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    자료구조
    데이터 타입
    java super
    데이터 크기
    java 에라토스테네스의 체
    java arrays.copyofrnage()
    java기초
    java 제어자
    개발로드맵
    java 유클리드 호제법
    Java this
    java
    Java 생성자
    java 세수의합
    java 메서드
    java enhance switch
    프로그래머스 java 기초 트레이닝
    java two-pointer
    java 멤버
    프로그래머스 java 기초트레이닝
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.1
DJ.Kang
34일차 - 알고리즘 코드카타
상단으로

티스토리툴바