πŸ’†πŸ»‍♂️ ν”Ό-μ—μŠ€/🐣 ν”„λ‘œκ·Έλž˜λ¨ΈμŠ€

[μŠ€μœ„ν”„νŠΈ μ•Œκ³ λ¦¬μ¦˜] ν”„λ‘œκ·Έλž˜λ¨ΈμŠ€: nμ§„μˆ˜ κ²Œμž„

κ°œλ°œν•˜λŠ” ν›ˆμ΄ 2021. 8. 29. 15:32

문제

https://programmers.co.kr/learn/courses/30/lessons/17687

 

μ½”λ”©ν…ŒμŠ€νŠΈ μ—°μŠ΅ - [3μ°¨] nμ§„μˆ˜ κ²Œμž„

Nμ§„μˆ˜ κ²Œμž„ νŠœλΈŒκ°€ ν™œλ™ν•˜λŠ” μ½”λ”© λ™μ•„λ¦¬μ—μ„œλŠ” μ „ν†΅μ μœΌλ‘œ ν•΄μ˜€λŠ” κ²Œμž„μ΄ μžˆλ‹€. 이 κ²Œμž„μ€ μ—¬λŸ¬ μ‚¬λžŒμ΄ λ‘₯κΈ€κ²Œ μ•‰μ•„μ„œ 숫자λ₯Ό ν•˜λ‚˜μ”© μ°¨λ‘€λŒ€λ‘œ λ§ν•˜λŠ” κ²Œμž„μΈλ°, κ·œμΉ™μ€ λ‹€μŒκ³Ό κ°™λ‹€. 숫자λ₯Ό 0

programmers.co.kr

Nμ§„μˆ˜ κ²Œμž„

νŠœλΈŒκ°€ ν™œλ™ν•˜λŠ” μ½”λ”© λ™μ•„λ¦¬μ—μ„œλŠ” μ „ν†΅μ μœΌλ‘œ ν•΄μ˜€λŠ” κ²Œμž„μ΄ μžˆλ‹€. 이 κ²Œμž„μ€ μ—¬λŸ¬ μ‚¬λžŒμ΄ λ‘₯κΈ€κ²Œ μ•‰μ•„μ„œ 숫자λ₯Ό ν•˜λ‚˜μ”© μ°¨λ‘€λŒ€λ‘œ λ§ν•˜λŠ” κ²Œμž„μΈλ°, κ·œμΉ™μ€ λ‹€μŒκ³Ό κ°™λ‹€.

  1. 숫자λ₯Ό 0λΆ€ν„° μ‹œμž‘ν•΄μ„œ μ°¨λ‘€λŒ€λ‘œ λ§ν•œλ‹€. 첫 번째 μ‚¬λžŒμ€ 0, 두 번째 μ‚¬λžŒμ€ 1, … μ—΄ 번째 μ‚¬λžŒμ€ 9λ₯Ό λ§ν•œλ‹€.
  2. 10 μ΄μƒμ˜ μˆ«μžλΆ€ν„°λŠ” ν•œ μžλ¦¬μ”© λŠμ–΄μ„œ λ§ν•œλ‹€. 즉 μ—΄ν•œ 번째 μ‚¬λžŒμ€ 10의 첫 자리인 1, 열두 번째 μ‚¬λžŒμ€ λ‘˜μ§Έ 자리인 0을 λ§ν•œλ‹€.

μ΄λ ‡κ²Œ κ²Œμž„μ„ 진행할 경우,
0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 1, 0, 1, 1, 1, 2, 1, 3, 1, 4, …
순으둜 숫자λ₯Ό λ§ν•˜λ©΄ λœλ‹€.

 

ν•œνŽΈ μ½”λ”© 동아리 일원듀은 컴퓨터λ₯Ό λ‹€λ£¨λŠ” μ‚¬λžŒλ‹΅κ²Œ μ΄μ§„μˆ˜λ‘œ 이 κ²Œμž„μ„ μ§„ν–‰ν•˜κΈ°λ„ ν•˜λŠ”λ°, 이 κ²½μš°μ—λŠ”
0, 1, 1, 0, 1, 1, 1, 0, 0, 1, 0, 1, 1, 1, 0, 1, 1, 1, …
순으둜 숫자λ₯Ό λ§ν•˜λ©΄ λœλ‹€.

 

μ΄μ§„μˆ˜λ‘œ μ§„ν–‰ν•˜λŠ” κ²Œμž„μ— μ΅μˆ™ν•΄μ Έ μ§ˆλ €κ°€λ˜ μ‚¬λžŒλ“€μ€ μ’€ 더 λ‚œμ΄λ„λ₯Ό 높이기 μœ„ν•΄ μ΄μ§„λ²•μ—μ„œ μ‹­μœ‘μ§„λ²•κΉŒμ§€ λͺ¨λ“  μ§„λ²•μœΌλ‘œ κ²Œμž„μ„ μ§„ν–‰ν•΄λ³΄κΈ°λ‘œ ν–ˆλ‹€. 숫자 κ²Œμž„μ΄ μ΅μˆ™ν•˜μ§€ μ•Šμ€ νŠœλΈŒλŠ” κ²Œμž„μ— μ Έμ„œ λ²ŒμΉ™μ„ λ°›λŠ” κ΅΄μš•μ„ ν”Όν•˜κΈ° μœ„ν•΄, μžμ‹ μ΄ 말해야 ν•˜λŠ” 숫자λ₯Ό μŠ€λ§ˆνŠΈν°μ— 미리 좜λ ₯ν•΄μ£ΌλŠ” ν”„λ‘œκ·Έλž¨μ„ λ§Œλ“€λ €κ³  ν•œλ‹€. 튜브의 ν”„λ‘œκ·Έλž¨μ„ κ΅¬ν˜„ν•˜λΌ.

μž…λ ₯ ν˜•μ‹

진법 n, 미리 ꡬ할 숫자의 갯수 t, κ²Œμž„μ— μ°Έκ°€ν•˜λŠ” 인원 m, 튜브의 μˆœμ„œ p κ°€ 주어진닀.

  • 2 ≦ n β‰¦ 16
  • 0 < t β‰¦ 1000
  • 2 ≦ m β‰¦ 100
  • 1 ≦ p β‰¦ m

좜λ ₯ ν˜•μ‹

νŠœλΈŒκ°€ 말해야 ν•˜λŠ” 숫자 t개λ₯Ό 곡백 없이 μ°¨λ‘€λŒ€λ‘œ λ‚˜νƒ€λ‚Έ λ¬Έμžμ—΄. 단, 10~15λŠ” 각각 λŒ€λ¬Έμž A~F둜 좜λ ₯ν•œλ‹€.

풀이

숫자λ₯Ό μŠ€μœ„ν”„νŠΈμ—μ„œ μ œκ³΅ν•˜λŠ” ν¬λ§·νŒ…μœΌλ‘œ μ§„μˆ˜λ³€ν™˜ν•˜κ³  μˆœμ„œλŒ€λ‘œ μ‚¬μš©ν•΄μ£ΌλŠ” κ²ƒμœΌλ‘œ μ‰½κ²Œ ν•΄κ²°ν•  수 μžˆμŠ΅λ‹ˆλ‹€. 그런데 μ§„μˆ˜μ— 따라 ν•œ 숫자λ₯Ό ν•˜λ‚˜μ˜ 문자둜 ν‘œν˜„ν•  수 μ—†λŠ” κ²½μš°κ°€ μžˆμŠ΅λ‹ˆλ‹€. 이λ₯Ό μœ„ν•΄μ„œ 큐λ₯Ό ν•˜λ‚˜ λ§Œλ“€κ³ , 큐에 μžˆλŠ” λ¬ΈμžλŠ” ν•˜λ‚˜μ”©λ§Œ μ‚¬μš©ν•˜λ©΄μ„œ μƒˆλ‘œμš΄ μˆ«μžλŠ” 큐가 λΉ„μ–΄μžˆμ„ λ•Œλ§Œ μƒˆλ‘œ λ³€ν™˜ν•˜λ„λ‘ ν•˜λ©΄ 문자λ₯Ό λ‹€ μ‚¬μš©ν–ˆμ„ λ•Œλ§Œ λ‹€μŒ 숫자둜 λ„˜μ–΄κ°€λ„λ‘ ν•  수 μžˆμŠ΅λ‹ˆλ‹€.

μ½”λ“œ