2개 이하로 다른 비트 (x보다 큰 1~2비트 다른 가장 작은 수)

2023. 7. 11. 14:39·Coding Test/programmers
728x90

https://school.programmers.co.kr/learn/courses/30/lessons/77885

 

프로그래머스

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

programmers.co.kr

 

분석

x보다 크고 x와 비트가 1~2개 다른 수들 중에서 제일 작은 수

  1. 숫자가 짝수인 경우
    • 항상 가장 마지막 비트는 0이다. 따라서 마지막 비트를 0에서 1로 바꿔준 값이 답이기 때문에 숫자+1 값을 answer에 넣어준다.
  2. 숫자가 홀수인 경우
    • 가장 뒤쪽에 있는 0을 1로 바꿔주고 그다음 비트를 0으로 바꿔주면 된다.
    • 예를 들어 7(0111) 은 가장 뒤쪽에 있는 0을 1로 바꿔주고 그다음 비트를 0으로 바꿔준다. 즉, 11(1011)이 답이다.
    • 그리고 9(1001) 은 1001 -> 1011 -> 1010 으로 10이 답이다.

 

f(7) = 11

수 비트 다른 비트의 개수
7 000...0111  
8 000...1000 4
9 000...1001 3
10 000...1010 3
11 000...1011 2
7보다 큰 수들 중에서 비트가 다른 지점이 2개 이하이면서 제일 작은 수가 11이기 때문

 

풀이

def solution(numbers):
    answer = []

    for x in numbers:
        if x%2==0: # 짝수
            answer.append(x+1)    
        else: # 홀수
            b='0'+bin(x)[2:]
            # 가장 뒤쪽에 있는 0을 1로 바꿔주고 그다음 비트를 0으로 바꿔주면 된다
            b=b[:b.rindex('0')]+'10'+b[b.rindex('0')+2:]
            answer.append(int(b, 2))            

    return answer

 

 

월간코드챌린지

728x90
저작자표시 비영리 변경금지 (새창열림)
'Coding Test/programmers' 카테고리의 다른 글
  • 당구연습 (그래프, 구현)
  • 빛의 경로 사이클 (그래프, 모든 좌표, 네방향 탐색)
  • 다리를 지나는 트럭 (다리 큐, 대기 큐)
  • 숫자의 표현 (약수의 개수)
Karla Ko
Karla Ko
𝘾𝙤𝙣𝙩𝙞𝙣𝙪𝙤𝙪𝙨𝙡𝙮 𝙄𝙢𝙥𝙧𝙤𝙫𝙞𝙣𝙜, 𝘾𝙤𝙣𝙨𝙩𝙖𝙣𝙩𝙡𝙮 𝘿𝙚𝙫𝙚𝙡𝙤𝙥𝙞𝙣𝙜 𝙔𝙚𝙨!
    250x250
  • Karla Ko
    karlaLog
    Karla Ko
  • 전체
    오늘
    어제
    • Total (467)
      • Spring (19)
      • JPA (4)
      • Cloud & Architecture (15)
        • Kubernetes (5)
        • Docker (3)
        • MSA (2)
        • GCP (1)
        • AWS (4)
      • Devops (1)
      • Message Queue (4)
        • Kafka (2)
        • RabbitMQ (2)
      • Git (4)
      • DB (4)
      • Java (9)
      • Python (4)
      • CS (11)
        • OS (8)
        • Network (2)
        • Algorithm (1)
      • Coding Test (392)
        • programmers (156)
        • Graph (43)
        • DP (37)
        • Search (31)
        • Tree (13)
        • Data Structure (26)
        • Combination (12)
        • Implement (18)
        • Geedy (23)
        • Sort (7)
        • Math (21)
        • geometry (2)
  • 블로그 메뉴

    • 홈
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    파이썬
    조합
    구간합
    알고리즘
    동적계획법
    덱
    스택
    구현
    재귀
    이분탐색
    다익스트라
    BFS
    LIS
    힙
    트리
    플로이드워셜
    최대공약수
    정렬
    최소신장트리
    큐
    프로그래머스
    그래프
    자료구조
    월간코드챌린지
    백준
    그리디
    DFS
    최단거리
    Algorithm
    DP
  • hELLO· Designed By정상우.v4.10.3
Karla Ko
2개 이하로 다른 비트 (x보다 큰 1~2비트 다른 가장 작은 수)
상단으로

티스토리툴바