ABOUT ME

-

Today
-
Yesterday
-
Total
-
  • [๋ฐฑ์ค€] 15656 N๊ณผ M (7) with Python
    PS 2023. 4. 18. 17:32
    728x90
    ๋ฐ˜์‘ํ˜•

    ๐Ÿ“Œ BOJ 15656 N๊ณผ M (7)

    ๐Ÿ’ก ์กฐ๊ฑด

    1. N๊ฐœ์˜ ์ž์—ฐ์ˆ˜์™€ ์ž์—ฐ์ˆ˜ M์ด ์ฃผ์–ด์กŒ์„ ๋•Œ, ์•„๋ž˜ ์กฐ๊ฑด์„ ๋งŒ์กฑํ•˜๋Š” ๊ธธ์ด๊ฐ€ M์ธ ์ˆ˜์—ด์„ ๋ชจ๋‘ ๊ตฌํ•˜๋Š” ํ”„๋กœ๊ทธ๋žจ์„ ์ž‘์„ฑํ•˜๋Š” ๋ฌธ์ œ.
      N๊ฐœ์˜ ์ž์—ฐ์ˆ˜๋Š” ๋ชจ๋‘ ๋‹ค๋ฅธ ์ˆ˜์ด๋‹ค.
    2. N๊ฐœ์˜ ์ž์—ฐ์ˆ˜ ์ค‘์—์„œ M๊ฐœ๋ฅผ ๊ณ ๋ฅธ ์ˆ˜์—ด
      ๊ฐ™์€ ์ˆ˜๋ฅผ ์—ฌ๋Ÿฌ ๋ฒˆ ๊ณจ๋ผ๋„ ๋œ๋‹ค.
    3. ์ฒซ์งธ ์ค„์— N๊ณผ M์ด ์ฃผ์–ด์ง„๋‹ค. (1 โ‰ค M โ‰ค N โ‰ค 7)
    4. ๋‘˜์งธ ์ค„์— N๊ฐœ์˜ ์ˆ˜๊ฐ€ ์ฃผ์–ด์ง„๋‹ค. ์ž…๋ ฅ์œผ๋กœ ์ฃผ์–ด์ง€๋Š” ์ˆ˜๋Š” 10,000๋ณด๋‹ค ์ž‘๊ฑฐ๋‚˜ ๊ฐ™์€ ์ž์—ฐ์ˆ˜์ด๋‹ค.
    5. ํ•œ ์ค„์— ํ•˜๋‚˜์”ฉ ๋ฌธ์ œ์˜ ์กฐ๊ฑด์„ ๋งŒ์กฑํ•˜๋Š” ์ˆ˜์—ด์„ ์ถœ๋ ฅํ•œ๋‹ค. ์ค‘๋ณต๋˜๋Š” ์ˆ˜์—ด์„ ์—ฌ๋Ÿฌ ๋ฒˆ ์ถœ๋ ฅํ•˜๋ฉด ์•ˆ๋˜๋ฉฐ,
      ์ˆ˜์—ด์€ ๊ณต๋ฐฑ์œผ๋กœ ๊ตฌ๋ถ„ํ•ด์„œ ์ถœ๋ ฅํ•ด์•ผ ํ•œ๋‹ค. ์ˆ˜์—ด์€ ์‚ฌ์ „ ์ˆœ์œผ๋กœ ์ฆ๊ฐ€ํ•˜๋Š” ์ˆœ์„œ๋กœ ์ถœ๋ ฅํ•ด์•ผ ํ•œ๋‹ค.
    6. ๋ฐฑํŠธ๋ž˜ํ‚น ์œ ํ˜•์˜ ๋ฌธ์ œ

    ๐Ÿ”– ์˜ˆ์ œ ๋ฐ ์‹คํ–‰๊ฒฐ๊ณผ

    ์˜ˆ์ œ 1

    3 1
    4 5 2

    ์‹คํ–‰๊ฒฐ๊ณผ 1

    2
    4
    5

    ์˜ˆ์ œ 2

    4 2
    9 8 7 1

    ์‹คํ–‰๊ฒฐ๊ณผ 2

    1 1
    1 7
    1 8
    1 9
    7 1
    7 7
    7 8
    7 9
    8 1
    8 7
    8 8
    8 9
    9 1
    9 7
    9 8
    9 9

    ์˜ˆ์ œ 3

    3 3
    1231 1232 1233

    ์‹คํ–‰๊ฒฐ๊ณผ 3

    1231 1231 1231
    1231 1231 1232
    1231 1231 1233
    1231 1232 1231
    1231 1232 1232
    1231 1232 1233
    1231 1233 1231
    1231 1233 1232
    1231 1233 1233
    1232 1231 1231
    1232 1231 1232
    1232 1231 1233
    1232 1232 1231
    1232 1232 1232
    1232 1232 1233
    1232 1233 1231
    1232 1233 1232
    1232 1233 1233
    1233 1231 1231
    1233 1231 1232
    1233 1231 1233
    1233 1232 1231
    1233 1232 1232
    1233 1232 1233
    1233 1233 1231
    1233 1233 1232
    1233 1233 1233

    โŒจ๏ธ ๋ฌธ์ œ ํ’€์ด

    1. ์ˆœํšŒํ•˜๋Š” arr์˜ ์›์†Œ๋ฅผ res ๋ฐฐ์—ด์— ๋„ฃ์œผ๋ฉด์„œ cnt๊ฐ€ m๊ณผ ๊ฐ™์•„ ์งˆ ๋•Œ, res์˜ ์›์†Œ๋ฅผ ์ถœ๋ ฅํ•œ๋‹ค.
    2. setrecursionlimit์„ ๋ฐ˜๋“œ์‹œ ํ•ด์ฃผ์–ด์•ผ ํ•œ๋‹ค.

    ๐Ÿ–ฅ ์†Œ์Šค ์ฝ”๋“œ

    from sys import stdin, setrecursionlimit
    
    setrecursionlimit(10 ** 7)
    
    n, m = map(int, stdin.readline().split())
    arr = list(map(int, stdin.readline().split()))
    arr.sort()
    
    
    def f(res, cnt):
        if cnt == m:
            print(*res)
            return
    
        for i in arr:
            f(res + [i], cnt + 1)
    
    
    f([], 0)
    ๋ฐ˜์‘ํ˜•

    ๋Œ“๊ธ€

Designed by Tistory.