[Programmers]์‹ ๊ทœ ์•„์ด๋”” ์ถ”์ฒœ

2022. 4. 5. 17:12ยท๐Ÿ’ฏ CodingTest/Programmers

์‹ ๊ทœ ์•„์ด๋”” ์ถ”์ฒœ

์‹ ๊ทœ ์•„์ด๋”” ์ถ”์ฒœ


๋ฌธ์ œ

์นด์นด์˜ค์— ์ž…์‚ฌํ•œ ์‹ ์ž… ๊ฐœ๋ฐœ์ž ๋„ค์˜ค๋Š” "์นด์นด์˜ค๊ณ„์ •๊ฐœ๋ฐœํŒ€"์— ๋ฐฐ์น˜๋˜์–ด, ์นด์นด์˜ค ์„œ๋น„์Šค์— ๊ฐ€์ž…ํ•˜๋Š” ์œ ์ €๋“ค์˜ ์•„์ด๋””๋ฅผ ์ƒ์„ฑํ•˜๋Š” ์—…๋ฌด๋ฅผ ๋‹ด๋‹นํ•˜๊ฒŒ ๋˜์—ˆ์Šต๋‹ˆ๋‹ค. "๋„ค์˜ค"์—๊ฒŒ ์ฃผ์–ด์ง„ ์ฒซ ์—…๋ฌด๋Š” ์ƒˆ๋กœ ๊ฐ€์ž…ํ•˜๋Š” ์œ ์ €๋“ค์ด ์นด์นด์˜ค ์•„์ด๋”” ๊ทœ์น™์— ๋งž์ง€ ์•Š๋Š” ์•„์ด๋””๋ฅผ ์ž…๋ ฅํ–ˆ์„ ๋•Œ, ์ž…๋ ฅ๋œ ์•„์ด๋””์™€ ์œ ์‚ฌํ•˜๋ฉด์„œ ๊ทœ์น™์— ๋งž๋Š” ์•„์ด๋””๋ฅผ ์ถ”์ฒœํ•ด์ฃผ๋Š” ํ”„๋กœ๊ทธ๋žจ์„ ๊ฐœ๋ฐœํ•˜๋Š” ๊ฒƒ์ž…๋‹ˆ๋‹ค.
๋‹ค์Œ์€ ์นด์นด์˜ค ์•„์ด๋””์˜ ๊ทœ์น™์ž…๋‹ˆ๋‹ค.

์•„์ด๋””์˜ ๊ธธ์ด๋Š” 3์ž ์ด์ƒ 15์ž ์ดํ•˜์—ฌ์•ผ ํ•ฉ๋‹ˆ๋‹ค.
์•„์ด๋””๋Š” ์•ŒํŒŒ๋ฒณ ์†Œ๋ฌธ์ž, ์ˆซ์ž, ๋นผ๊ธฐ(-), ๋ฐ‘์ค„(_), ๋งˆ์นจํ‘œ(.) ๋ฌธ์ž๋งŒ ์‚ฌ์šฉํ•  ์ˆ˜ ์žˆ์Šต๋‹ˆ๋‹ค.
๋‹จ, ๋งˆ์นจํ‘œ(.)๋Š” ์ฒ˜์Œ๊ณผ ๋์— ์‚ฌ์šฉํ•  ์ˆ˜ ์—†์œผ๋ฉฐ ๋˜ํ•œ ์—ฐ์†์œผ๋กœ ์‚ฌ์šฉํ•  ์ˆ˜ ์—†์Šต๋‹ˆ๋‹ค.
"๋„ค์˜ค"๋Š” ๋‹ค์Œ๊ณผ ๊ฐ™์ด 7๋‹จ๊ณ„์˜ ์ˆœ์ฐจ์ ์ธ ์ฒ˜๋ฆฌ ๊ณผ์ •์„ ํ†ตํ•ด ์‹ ๊ทœ ์œ ์ €๊ฐ€ ์ž…๋ ฅํ•œ ์•„์ด๋””๊ฐ€ ์นด์นด์˜ค ์•„์ด๋”” ๊ทœ์น™์— ๋งž๋Š” ์ง€ ๊ฒ€์‚ฌํ•˜๊ณ  ๊ทœ์น™์— ๋งž์ง€ ์•Š์€ ๊ฒฝ์šฐ ๊ทœ์น™์— ๋งž๋Š” ์ƒˆ๋กœ์šด ์•„์ด๋””๋ฅผ ์ถ”์ฒœํ•ด ์ฃผ๋ ค๊ณ  ํ•ฉ๋‹ˆ๋‹ค.
์‹ ๊ทœ ์œ ์ €๊ฐ€ ์ž…๋ ฅํ•œ ์•„์ด๋””๊ฐ€ new_id ๋ผ๊ณ  ํ•œ๋‹ค๋ฉด,

  • 1๋‹จ๊ณ„ new_id์˜ ๋ชจ๋“  ๋Œ€๋ฌธ์ž๋ฅผ ๋Œ€์‘๋˜๋Š” ์†Œ๋ฌธ์ž๋กœ ์น˜ํ™˜ํ•ฉ๋‹ˆ๋‹ค.
  • 2๋‹จ๊ณ„ new_id์—์„œ ์•ŒํŒŒ๋ฒณ ์†Œ๋ฌธ์ž, ์ˆซ์ž, ๋นผ๊ธฐ(-), ๋ฐ‘์ค„(_), ๋งˆ์นจํ‘œ(.)๋ฅผ ์ œ์™ธํ•œ ๋ชจ๋“  ๋ฌธ์ž๋ฅผ ์ œ๊ฑฐํ•ฉ๋‹ˆ๋‹ค.
  • 3๋‹จ๊ณ„ new_id์—์„œ ๋งˆ์นจํ‘œ(.)๊ฐ€ 2๋ฒˆ ์ด์ƒ ์—ฐ์†๋œ ๋ถ€๋ถ„์„ ํ•˜๋‚˜์˜ ๋งˆ์นจํ‘œ(.)๋กœ ์น˜ํ™˜ํ•ฉ๋‹ˆ๋‹ค.
  • 4๋‹จ๊ณ„ new_id์—์„œ ๋งˆ์นจํ‘œ(.)๊ฐ€ ์ฒ˜์Œ์ด๋‚˜ ๋์— ์œ„์น˜ํ•œ๋‹ค๋ฉด ์ œ๊ฑฐํ•ฉ๋‹ˆ๋‹ค.
  • 5๋‹จ๊ณ„ new_id๊ฐ€ ๋นˆ ๋ฌธ์ž์—ด์ด๋ผ๋ฉด, new_id์— "a"๋ฅผ ๋Œ€์ž…ํ•ฉ๋‹ˆ๋‹ค.
  • 6๋‹จ๊ณ„ new_id์˜ ๊ธธ์ด๊ฐ€ 16์ž ์ด์ƒ์ด๋ฉด, new_id์˜ ์ฒซ 15๊ฐœ์˜ ๋ฌธ์ž๋ฅผ ์ œ์™ธํ•œ ๋‚˜๋จธ์ง€ ๋ฌธ์ž๋“ค์„ ๋ชจ๋‘ ์ œ๊ฑฐํ•ฉ๋‹ˆ๋‹ค.
    ๋งŒ์•ฝ ์ œ๊ฑฐ ํ›„ ๋งˆ์นจํ‘œ(.)๊ฐ€ new_id์˜ ๋์— ์œ„์น˜ํ•œ๋‹ค๋ฉด ๋์— ์œ„์น˜ํ•œ ๋งˆ์นจํ‘œ(.) ๋ฌธ์ž๋ฅผ ์ œ๊ฑฐํ•ฉ๋‹ˆ๋‹ค.
  • 7๋‹จ๊ณ„ new_id์˜ ๊ธธ์ด๊ฐ€ 2์ž ์ดํ•˜๋ผ๋ฉด, new_id์˜ ๋งˆ์ง€๋ง‰ ๋ฌธ์ž๋ฅผ new_id์˜ ๊ธธ์ด๊ฐ€ 3์ด ๋  ๋•Œ๊นŒ์ง€ ๋ฐ˜๋ณตํ•ด์„œ ๋์— ๋ถ™์ž…๋‹ˆ๋‹ค.

์ œํ•œ์‚ฌํ•ญ

new_id๋Š” ๊ธธ์ด 1 ์ด์ƒ 1,000 ์ดํ•˜์ธ ๋ฌธ์ž์—ด์ž…๋‹ˆ๋‹ค.
new_id๋Š” ์•ŒํŒŒ๋ฒณ ๋Œ€๋ฌธ์ž, ์•ŒํŒŒ๋ฒณ ์†Œ๋ฌธ์ž, ์ˆซ์ž, ํŠน์ˆ˜๋ฌธ์ž๋กœ ๊ตฌ์„ฑ๋˜์–ด ์žˆ์Šต๋‹ˆ๋‹ค.
new_id์— ๋‚˜ํƒ€๋‚  ์ˆ˜ ์žˆ๋Š” ํŠน์ˆ˜๋ฌธ์ž๋Š” -_.~!@#$%^&*()=+[{]}:?,<>/ ๋กœ ํ•œ์ •๋ฉ๋‹ˆ๋‹ค.


> 2021 KAKAO BLIND RECRUITMENT ๋ฌธ์ œ์ด๋‹ค.

๊ฐ ๋‹จ๊ณ„๋ณ„ ๊ทธ๋ฆฌ๋”” ์•Œ๊ณ ๋ฆฌ์ฆ˜์œผ๋กœ ๊ตฌํ˜„ํ•˜์˜€๋‹ค.


from collections import deque

def solution(new_id):
    answer =''
    # 1๋‹จ๊ณ„ : ์†Œ๋ฌธ์ž ๋ณ€ํ™˜
    new_id = new_id.lower()

    # 2๋‹จ๊ณ„ : ํŠน์ˆ˜๋ฌธ์ž ์ œ๊ฑฐ
    for c in new_id:
        if (97 <= ord(c) <= 122) or (48 <= ord(c) <= 57) or c == '-' or c == '_' or c == '.' :
            answer += c
        else : 
            continue


    # 3๋‹จ๊ณ„ : ๋งˆ์นจํ‘œ ์ค„์ด๊ธฐ
    temp =''
    dq = deque()
    for c in answer:
        if c == '.':
            dq.append(c)
        else : 
            if len(dq) > 0: 
                temp += dq.pop()
                dq.clear()
            temp += c
    answer = temp  



    # 4๋‹จ๊ณ„ : ์ฒ˜์Œ๊ณผ ๋ ๋งˆ์นจํ‘œ ์ œ๊ฑฐ
    if len(answer) > 0 and answer[0] == '.' :
        answer = answer[1:]

    if len(answer) > 0 and answer[len(answer)-1] == '.':
        answer = answer[:len(answer)-1]

     # 5๋‹จ๊ณ„ : ๋นˆ ๋ฌธ์ž์—ด์˜ ๊ฒฝ์šฐ a๋กœ ์น˜ํ™˜   
    if answer == '':
        answer = 'a'

    # 6๋‹จ๊ณ„ : ๊ธธ์ด๊ฐ€ 16์ž ์ด์ƒ์ด๋ผ๋ฉด ์ฒซ 15๊ฐœ์˜ ๋ฌธ์ž๋งŒ ์ถ”์ถœ
    if len(answer) >= 16 :
        answer = answer[0:15]

    print(answer)

    # 6-1๋‹จ๊ณ„: ๋งŒ์ผ ์ œ๊ฑฐ ํ›„ ๋งˆ์นจํ‘œ๊ฐ€ ๋์— ์žˆ๋‹ค๋ฉด ์ œ๊ฑฐ    
    if answer[len(answer)-1] == '.':
         answer = answer[:len(answer)-1]

    print(answer)

    # 7๋‹จ๊ณ„ : ๊ธธ์ด๊ฐ€ 2์ž ์ดํ•˜๋ผ๋ฉด, ๊ธธ์ด๊ฐ€ 3์ด ๋ ๋•Œ๊นŒ์ง€ ๋งˆ์ง€๋ง‰ ๋ฌธ์ž ๋ฐ˜๋ณต
    if len(answer) <= 2:
        addChar = answer[len(answer)-1]
        while len(answer) != 3 :
            answer += addChar

    # ์ฃผ์˜: ๋ฆฌ์ŠคํŠธ ์Šฌ๋ผ์ด์‹ฑ ์‚ฌ์šฉ์‹œ ๋’ท๊ตฌ๊ฐ„ ์—ด๋ฆฐ ๊ตฌ๊ฐ„์ธ ์  ๊ธฐ์–ตํ•˜๊ธฐ.

    return answer

  1. ๋จผ์ € ์ธ์ž๋กœ ๋“ค์–ด์˜จ ๋ฌธ์ž์—ด ์ค‘ ๋Œ€๋ฌธ์ž๋ฅผ ์†Œ๋ฌธ์ž๋กœ ๋ณ€ํ™˜.
  2. ํŠน์ˆ˜๋ฌธ์ž์ œ๊ฑฐ(ASCII ์ด์šฉ)
  3. ๋งˆ์นจํ‘œ ์ค„์ด๊ธฐ(replaceํ•จ์ˆ˜๋ฅผ ์ด์šฉํ•œ๋‹ค๋Š” ์ƒ๊ฐ์„ ํ•˜์ง€๋ชปํ•ด์„œ ์ผ๋‹จ deque์ž๋ฃŒ๊ตฌ์กฐ๋ฅผ ์ด์šฉํ•ด ์Šคํƒ์ฒ˜๋Ÿผ ์‚ฌ์šฉ)
  4. ์ฒ˜์Œ๊ณผ ๋ ๋งˆ์นจํ‘œ ์ œ๊ฑฐ(arrange error ๋ฐฉ์ง€)
  5. ๋นˆ ๋ฌธ์ž์—ด์˜ ๊ฒฝ์šฐ a๋กœ ์น˜ํ™˜
  6. ๊ธธ์ด๊ฐ€ 16์ž ์ด์ƒ์ด๋ผ๋ฉด ์•ž๋ถ€๋ถ„ 15๊ฐœ์˜ ๋ฌธ์ž์—ด ์ถ”์ถœ
    6-1. ์ถ”์ถœํ›„ ๊ฐ€์žฅ ๋ ๋ฌธ์ž๊ฐ€ ๋งˆ์นจํ‘œ('.')๋ผ๋ฉด ์ œ๊ฑฐ
  7. ๊ธธ์ด๊ฐ€ 2๊ธ€์ž ์ดํ•˜๋ผ๋ฉด, ๊ธธ์ด๊ฐ€ 3์ด ๋ ๋•Œ๊นŒ์ง€ ๋งˆ์ง€๋ง‰ ๋ฌธ์ž ๋ฐ˜๋ณต

์ฃผ์˜ :

๋ฆฌ์ŠคํŠธ ์Šฌ๋ผ์ด์‹ฑ ์‚ฌ์šฉ์‹œ ๋’ท๊ตฌ๊ฐ„์ด ์—ด๋ฆฐ ๊ตฌ๊ฐ„์ธ ์ ์„ ํ•ญ์ƒ ์žŠ์ง€๋ง์ž(์ด๊ฑฐ ๋•Œ๋ฌธ์— ์‹œ๊ฐ„์ด ์˜ค๋ž˜ ๊ฑธ๋ ธ๋„ค์š”.)

๋ฌธ์ œ์ถœ์ฒ˜ : ํ”„๋กœ๊ทธ๋ž˜๋จธ์Šค https://programmers.co.kr/

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

[Programmers] ์ˆซ์ž ๋ฌธ์ž์—ด๊ณผ ์˜๋‹จ์–ด  (0) 2022.04.09
[Programmers] ์‹ ๊ณ ๊ฒฐ๊ณผ ๋ฐ›๊ธฐ  (0) 2022.04.09
[Programmers]๋ถ€์กฑํ•œ ๊ธˆ์•ก ๊ณ„์‚ฐํ•˜๊ธฐ  (0) 2022.04.05
[Programmers]์ „ํ™”๋ฒˆํ˜ธ ๋ชฉ๋ก - ํ•ด์‹œ  (0) 2022.04.05
[Programmers]์™„์ฃผํ•˜์ง€ ๋ชปํ•œ ์„ ์ˆ˜ - ํ•ด์‹œ  (0) 2022.04.05
'๐Ÿ’ฏ CodingTest/Programmers' ์นดํ…Œ๊ณ ๋ฆฌ์˜ ๋‹ค๋ฅธ ๊ธ€
  • [Programmers] ์ˆซ์ž ๋ฌธ์ž์—ด๊ณผ ์˜๋‹จ์–ด
  • [Programmers] ์‹ ๊ณ ๊ฒฐ๊ณผ ๋ฐ›๊ธฐ
  • [Programmers]๋ถ€์กฑํ•œ ๊ธˆ์•ก ๊ณ„์‚ฐํ•˜๊ธฐ
  • [Programmers]์ „ํ™”๋ฒˆํ˜ธ ๋ชฉ๋ก - ํ•ด์‹œ
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)
  • ๋ธ”๋กœ๊ทธ ๋ฉ”๋‰ด

    • ๋งํฌ

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

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

    • ํƒœ๊ทธ

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

    • ์ตœ๊ทผ ๊ธ€

    • hELLOยท Designed By์ •์ƒ์šฐ.v4.10.1
    S.Honey
    [Programmers]์‹ ๊ทœ ์•„์ด๋”” ์ถ”์ฒœ
    ์ƒ๋‹จ์œผ๋กœ

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