[프로그래머스] Level2, 영어 끝말잇기 (Python)

2021. 6. 9. 15:09·알고리즘/프로그래머스
728x90
반응형

문제

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

 

코딩테스트 연습 - 영어 끝말잇기

3 ["tank", "kick", "know", "wheel", "land", "dream", "mother", "robot", "tank"] [3,3] 5 ["hello", "observe", "effect", "take", "either", "recognize", "encourage", "ensure", "establish", "hang", "gather", "refer", "reference", "estimate", "executive"] [0,0]

programmers.co.kr

 

코드

def solution(n, words):
    answer = []
    temp = []
    temp.append(words[0])
    result1 = 0
    result2 = 0
    for i in range(1, len(words)):
        if words[i-1][-1] == words[i][0]:
            if words[i] not in temp:
                temp.append(words[i])
            else:
                result1 = i % n + 1 # 몇번째 사람이 떨어졌는지
                result2 = i // n + 1 # 떨어진 사람이 몇번째에 떨어졌는지
                return [result1, result2]
        else:
            result1 = i % n + 1 # 몇번째 사람이 떨어졌는지
            result2 = i // n + 1 # 떨어진 사람이 몇번째에 떨어졌는지
            return [result1, result2]
    else:
        return [0,0]

끝말잇기 배열이 주어졌을때 끝말잇기가 실패하는 경우가 두가지가 있다.

 

첫번째는 전단어에 맨마지막 단어와 현재 첫번째 단어가 같지 않을 경우

=> 전 단어에 맨 마지막 글자와 현재 단어에 맨 처음 글자를 비교하여 같지않을 경우 return을 시켜주도록 한다.

 

두번째는 썻던 단어를 또 쓰는 경우

=> temp 배열을 임시로 만들어 temp에 들어있지 않은 문자열을 append 시켜주고 temp에 존재하는 문자열일 경우에는 return을 시켜주도록 한다.

 

몇번째 사람이 떨어졌는지는 나머지 숫자로 구할 수 있다.

인덱스 % 사람수 + 1 을 해주면 구할 수 있다. (인덱스 이므로 +1을 해준다.)

 

떨어진 사람이 몇번째에 떨어졌는지는 몫으로 구할 수 있다.

인덱스 // 사람수 + 1 을 해주면 구할 수 있다. (인덱스 이므로 +1을 해준다.)

반응형
저작자표시 (새창열림)

'알고리즘 > 프로그래머스' 카테고리의 다른 글

[프로그래머스] Level2, 삼각 달팽이 (Python)  (0) 2021.06.10
[프로그래머스] Level2, 이진 변환 반복하기 (Python)  (0) 2021.06.09
[프로그래머스] Level2, 가장 큰 정사각형 찾기 (Python)  (0) 2021.06.08
[프로그래머스] Level2, 올바른 괄호 (Python)  (0) 2021.06.08
[프로그래머스] Level2, 땅따먹기 (Python)  (0) 2021.06.08
'알고리즘/프로그래머스' 카테고리의 다른 글
  • [프로그래머스] Level2, 삼각 달팽이 (Python)
  • [프로그래머스] Level2, 이진 변환 반복하기 (Python)
  • [프로그래머스] Level2, 가장 큰 정사각형 찾기 (Python)
  • [프로그래머스] Level2, 올바른 괄호 (Python)
wookcode
wookcode
공부한 내용들을 정리하고 기록하는 블로그입니다.
    반응형
  • wookcode
    wookcode
    wookcode
  • 전체
    오늘
    어제
    • 카테고리 (196) N
      • study (1) N
        • 아파치 카프카 애플리케이션 프로그래밍 with 자.. (0)
        • 인프런 (1) N
      • Live Study (15)
      • Programming (14)
        • Java (8)
        • Python (1)
        • Springboot (5)
        • MSA (0)
      • 알고리즘 (117)
        • 백준 (58)
        • 프로그래머스 (59)
      • 에러로그 (5)
      • 항해99 (23)
      • 면접 (1)
      • 프로젝트 (1)
      • CS (19)
        • 네트워크 (2)
        • 운영체제 (2)
        • 데이터베이스 (2)
        • 컴퓨터구조 (1)
        • Java (8)
        • Spring (4)
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    orm
    java
    그리디
    백준
    브루트포스
    코딩테스트
    카카오코딩테스트
    조합
    후기
    항해99
    버그
    jpa
    미니프로젝트
    괄호
    spring
    프로그래머스
    파이썬
    SFlash
    해결
    회고
    인프런
    김영한
    에러
    정리
    실전프로젝트
    항해마켓
    SpringBoot
    카카오인턴
    알고리즘
    스파르타코딩클럽
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.4
wookcode
[프로그래머스] Level2, 영어 끝말잇기 (Python)
상단으로

티스토리툴바