[BaekJoon] 1654 ๋žœ์„  ์ž๋ฅด๊ธฐ

2022. 4. 11. 10:14ยท๐Ÿ’ฏ CodingTest/BaekJoon

[์ถœ์ฒ˜ : https://www.acmicpc.net/problem/1654]

 

k, n = map(int,input().split())

kLength = list()
result = list()

for i in range(k):
    kLength.append(int(input()))

kLength.sort()


def binarySearch(data, n2):
    low=1
    # ๋žœ์„ ์˜ ๊ธธ์ด๋Š” ์ž์—ฐ์ˆ˜๋ผ๊ณ  ๋ช…์‹œ๋˜์–ด์žˆ๋‹ค..
    # ์กฐ์‹ฌํ•˜์ž..
    # low๋ฅผ 0์œผ๋กœ ํ•ด๋†“๊ณ  ํ—›์ง“๊ฑฐ๋ฆฌํ•จ..
    high = data[len(data)-1] + 1
    '''
     4 4
     100
     100
     100
     100
     ๊ณผ ๊ฐ™์€ ์ž…๋ ฅ์ด ๋“ค์–ด์™”์„๋•Œ high๊ฐ’๋„ ํƒ์ƒ‰ ๋ฒ”์œ„์— ํฌํ•จ์‹œํ‚ค๊ธฐ ์œ„ํ•ด 1๋”ํ•ด์ฃผ๊ธฐ.
    '''

    while (low <= high):
        # while ์กฐ๊ฑด์„ ๋‹จ์ˆœํžˆ low ๊ฐ€ ์ž‘์€ ๊ฒฝ์šฐ๋กœ๋งŒ ํ•ด์ฃผ๋ฉด high์™€ low๊ฐ€ ๊ฐ™์€ ๊ฒฝ์šฐ์˜ ๊ฐ’์€ ๋น„๊ต๋ฅผ ์ง„ํ–‰ํ•˜์ง€ ์•Š์Œ
        # ์ด์ง„ํƒ์ƒ‰ ์กฐ๊ฑด์„ ์ž˜ ์ƒ๊ฐํ•ด๋ณด์ž. ๊ทธ๋ฆฌ๊ณ  ๊ฐ€๋Šฅํ•œ low <= high ์œผ๋กœ ์‚ฌ์šฉํ•ด๋ณด์ž
        mid = (low + high) // 2
        total = 0
        for kl in data:
            total += kl // mid
       
        if total >= n2 :
            result.append(mid)
            low = mid + 1
        else:
            high = mid - 1

# mid ๊ฐ€ 0์ธ๊ฒฝ์šฐ ์ƒ๊ฐํ•ด๋ณด๊ธฐ
binarySearch(kLength, n)

print(max(result))

 

๋ฌธ์ œํ’€์ด

 

1. ์ดˆ๊ธฐ ์ž…๋ ฅ๋ฌธ ์ฒ˜๋ฆฌ

2. ๊ฐ๊ฐ์˜ ๋žœ์„  ๊ธธ์ด๋Š” kLength ๋ฆฌ์ŠคํŠธ์— ์ €์žฅ => ๊ทธ ํ›„ ์ •๋ ฌ

3. ์ด์ง„ ํƒ์ƒ‰ ํ•จ์ˆ˜ ์ž‘์„ฑ => ๊ฐ ์ค‘๊ฐ„๊ฐ’์„ ๋ฐ˜๋ณตํ• ๋•Œ๋งˆ๋‹ค ๊ทธ๋•Œ ๊ธธ์ด๋กœ ๊ฐ๊ฐ์˜ ๋žœ์„ ์—์„œ ๋‚˜์˜ฌ ์ˆ˜ ์žˆ๋Š” ๊ฐœ์ˆ˜๋ฅผ ๊ตฌํ•˜๊ณ  ๊ฐœ์ˆ˜๊ฐ€ ๊ธฐ์ค€๊ฐ’๋ณด๋‹ค ํฌ๊ฑฐ๋‚˜ ๊ฐ™์€ ๊ฒฝ์šฐ๋Š” low๊ฐ’์„ ์˜ฌ๋ ค ํƒ์ƒ‰ํ•˜๋„๋ก ๊ตฌํ˜„ ์ด๋•Œ ์กฐ๊ฑด์— ๋งž๋Š” ๊ธฐ์ค€๊ฐ’๋“ค์€ result ๋ฆฌ์ŠคํŠธ์— append

4. binarySearch() ํ•จ์ˆ˜ ํ˜ธ์ถœ

5. ๊ฒฐ๊ณผ ์ถœ๋ ฅ 

 

'๐Ÿ’ฏ CodingTest > BaekJoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€

[BaekJoon] 18111 ๋งˆ์ธํฌ๋ž˜ํ”„ํŠธ  (0) 2022.04.11
[BaekJoon] 15829 Hashing  (0) 2022.04.11
[BaekJoon] 2805 ๋‚˜๋ฌด์ž๋ฅด๊ธฐ  (0) 2022.04.11
[BaekJoon] 10845 ํ  (0) 2022.04.11
[BaekJoon] 1081 ์ˆซ์ž ์นด๋“œ 2  (0) 2022.04.11
'๐Ÿ’ฏ CodingTest/BaekJoon' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [BaekJoon] 15829 Hashing
  • [BaekJoon] 2805 ๋‚˜๋ฌด์ž๋ฅด๊ธฐ
  • [BaekJoon] 10845 ํ
  • [BaekJoon] 1081 ์ˆซ์ž ์นด๋“œ 2
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)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

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

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

    • ํƒœ๊ทธ

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

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    [BaekJoon] 1654 ๋žœ์„  ์ž๋ฅด๊ธฐ
    ์ƒ๋‹จ์œผ๋กœ

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