Binary Search (์ด์ง„ํƒ์ƒ‰)

2022. 4. 9. 23:45ยท๐Ÿ“š Computer Science/Algorithms
  • ์ •๋ ฌ๋œ ๋ฆฌ์ŠคํŠธ์˜ ๋ฒ”์œ„๋ฅผ ๋ฐ˜์”ฉ ๋‚˜๋ˆ„์–ด ํƒ์ƒ‰์„ ์ง„ํ–‰ํ•˜๋Š” ๋ฐฉ๋ฒ•
  • ์ •๋ ฌ๋œ ๋ฆฌ์ŠคํŠธ์—์„œ๋งŒ ์‚ฌ์šฉ๊ฐ€๋Šฅ
  • ์†๋„๊ฐ€ ๋น ๋ฆ„
์ƒํ™ฉ ์†๋„
์ตœ์  O(1)
๋ณดํ†ต O(logn)
์ตœ์•… O(logn)

๋™์ž‘

  1. ๋ฐฐ์—ด์˜ ์ค‘๊ฐ„๊ฐ’ ์„ค์ •
  2. ์ค‘๊ฐ„๊ฐ’๊ณผ ๊ฒ€์ƒ‰๊ฐ’ ๋น„๊ต
    1. ๊ฒ€์ƒ‰๊ฐ’๊ณผ ๊ฐ™์€ ๊ฒฝ์šฐ - ํƒ์ƒ‰์™„๋ฃŒ
    2. ๊ฒ€์ƒ‰๊ฐ’์ด ์ค‘๊ฐ„๊ฐ’๋ณด๋‹ค ํฐ ๊ฒฝ์šฐ - low๋ฅผ ์ค‘๊ฐ„๊ฐ’+1 ๋กœ ์กฐ์ •
    3. ๊ฒ€์ƒ‰๊ฐ’์ด ์ค‘๊ฐ„๊ฐ’๋ณด๋‹ค ์ž‘์€ ๊ฒฝ์šฐ - high๋ฅผ ์ค‘๊ฐ„๊ฐ’-1 ๋กœ ์กฐ์ •
  3. low๊ฐ€ high๋ณด๋‹ค ์ž‘๊ฑฐ๋‚˜ ๊ฐ™์€๊ฒฝ์šฐ๊นŒ์ง€ ๋ฐ˜๋ณต(๊ฐ’์„ ์ฐพ์€ ๊ฒฝ์šฐ๊ฐ€ ์•„๋‹ˆ๋ผ๋ฉด)

์ด์ง„ํƒ์ƒ‰ ๊ตฌํ˜„

def binarySearch(data, num):
    low = 0
    high = len(data) - 1

    while(low <= high):
        mid = (low + high) // 2

        if num == data[mid]:
            return True
        elif num > data[mid]:
            low = mid + 1 
        else :
            high = mid - 1

    return False

์ด์ง„ํƒ์ƒ‰ ์‚ฌ์šฉ ์˜ˆ์‹œ ์ฝ”๋“œ

n = int(input())
data1 = list(map(int,input().split()))
m = int(input())
data2 = list(map(int,input().split()))

data1.sort()

def binarySearch(data, num):
    low = 0
    high = len(data) - 1

    while(low <= high):
        mid = (low + high) // 2

        if num == data[mid]:
            return True
        elif num > data[mid]:
            low = mid + 1 
        else :
            high = mid - 1

    return False

for num in data2:
    if binarySearch(data1, num) :
        print(1)
    else:
        print(0)

'๐Ÿ“š Computer Science > Algorithms' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

GCD & LCM(์ตœ๋Œ€๊ณต์•ฝ์ˆ˜ & ์ตœ์†Œ๊ณต๋ฐฐ์ˆ˜)  (0) 2022.04.09
Cocktail Sort(์นตํ…Œ์ผ ์ •๋ ฌ)  (0) 2022.04.09
Bubble Sort(๋ฒ„๋ธ” ์ •๋ ฌ)  (0) 2022.04.09
'๐Ÿ“š Computer Science/Algorithms' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • GCD & LCM(์ตœ๋Œ€๊ณต์•ฝ์ˆ˜ & ์ตœ์†Œ๊ณต๋ฐฐ์ˆ˜)
  • Cocktail Sort(์นตํ…Œ์ผ ์ •๋ ฌ)
  • Bubble Sort(๋ฒ„๋ธ” ์ •๋ ฌ)
S.Honey
S.Honey
  • S.Honey
    Algo ์“ฐ์ž
    S.Honey
  • ์ „์ฒด
    ์˜ค๋Š˜
    ์–ด์ œ
    • ๋ถ„๋ฅ˜ ์ „์ฒด๋ณด๊ธฐ (123)
      • ํšŒ๊ณ  (0)
        • ์ทจ์—… ํ›„ ํšŒ๊ณ  (0)
      • ๐Ÿƒ Frontend Road-Map (2)
        • ๐Ÿšฉ Summary (1)
        • ๐Ÿ“š Road-Map Contents (1)
        • ๐ŸŸง HTML (0)
        • ๐ŸŸฆ CSS (0)
        • ๐ŸŸจ Javascript (0)
        • โฌœ React (0)
        • ๐ŸŸช Redux (0)
      • Backend (0)
        • QueryDSL (0)
      • ๐Ÿ’ป Programming Language (54)
        • C# (51)
        • Flutter-Dart (3)
        • Java (0)
      • ๐Ÿ“š Computer Science (4)
        • Algorithms (4)
        • Database (0)
        • Network (0)
        • Operating System(OS) (0)
      • ๐Ÿ’ฏ CodingTest (60)
        • BaekJoon (22)
        • Programmers (34)
        • CodeTree (4)
      • โœ’๏ธ Design Pattern (1)
      • ๐Ÿฑ Etc (2)
        • Jenkins Plugin ์ œ์ž‘๊ธฐ (1)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

    • ๊ณต์ง€์‚ฌํ•ญ

      • ๐Ÿ“– ๊ณต๋ถ€ ์ฐธ๊ณ  ๊ต์žฌ ๋ฐ ์ž๋ฃŒ
    • ์ธ๊ธฐ ๊ธ€

    • ํƒœ๊ทธ

      ๋ฌธ์ž์—ด ํŒŒ์‹ฑ
      sort
      BAEKJOON
      ์ฝ”๋“œํŠธ๋ฆฌ
      BFS
      ๋™์  ํ”„๋กœ๊ทธ๋ž˜๋ฐ
      programmers
      ์ž๋ฃŒ๊ตฌ์กฐ
      c#
      ์ฝ”๋”ฉํ…Œ์ŠคํŠธ
      ์‚ผ์„ฑsw์—ญํ…Œ
      ๋ฐฑ์ค€
      JS
      ๊ทธ๋ž˜ํ”„ ํƒ์ƒ‰
      ์ด์ง„ํƒ์ƒ‰
      ์นด์นด์˜ค
      ์ž๋ฐ”์Šคํฌ๋ฆฝํŠธ
      DP
      ์‹œ๋ฎฌ๋ ˆ์ด์…˜
      ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค
      JavaScript
      ์Šคํ„ฐ๋””
      DART
      ์•Œ๊ณ ๋ฆฌ์ฆ˜
      Algorithm
      ์“ฐ์…จ์ž–์•„
      ํŒŒ์ด์ฌ
      Flutter
      Java
      ๊ตฌํ˜„
    • ์ตœ๊ทผ ๋Œ“๊ธ€

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    Binary Search (์ด์ง„ํƒ์ƒ‰)
    ์ƒ๋‹จ์œผ๋กœ

    ํ‹ฐ์Šคํ† ๋ฆฌํˆด๋ฐ”

    ๋‹จ์ถ•ํ‚ค

    ๋‚ด ๋ธ”๋กœ๊ทธ

    ๋‚ด ๋ธ”๋กœ๊ทธ - ๊ด€๋ฆฌ์ž ํ™ˆ ์ „ํ™˜
    Q
    Q
    ์ƒˆ ๊ธ€ ์“ฐ๊ธฐ
    W
    W

    ๋ธ”๋กœ๊ทธ ๊ฒŒ์‹œ๊ธ€

    ๊ธ€ ์ˆ˜์ • (๊ถŒํ•œ ์žˆ๋Š” ๊ฒฝ์šฐ)
    E
    E
    ๋Œ“๊ธ€ ์˜์—ญ์œผ๋กœ ์ด๋™
    C
    C

    ๋ชจ๋“  ์˜์—ญ

    ์ด ํŽ˜์ด์ง€์˜ URL ๋ณต์‚ฌ
    S
    S
    ๋งจ ์œ„๋กœ ์ด๋™
    T
    T
    ํ‹ฐ์Šคํ† ๋ฆฌ ํ™ˆ ์ด๋™
    H
    H
    ๋‹จ์ถ•ํ‚ค ์•ˆ๋‚ด
    Shift + /
    โ‡ง + /

    * ๋‹จ์ถ•ํ‚ค๋Š” ํ•œ๊ธ€/์˜๋ฌธ ๋Œ€์†Œ๋ฌธ์ž๋กœ ์ด์šฉ ๊ฐ€๋Šฅํ•˜๋ฉฐ, ํ‹ฐ์Šคํ† ๋ฆฌ ๊ธฐ๋ณธ ๋„๋ฉ”์ธ์—์„œ๋งŒ ๋™์ž‘ํ•ฉ๋‹ˆ๋‹ค.