Algorithem

순열 찾기 (python code)

2023. 1. 5. 12:31

1. dfs 를 차용한 재귀

알고리즘 : dfs
구현 : 재귀

def dfs(mylist, visited = [], answer = []) :
    if len(visited) == len(mylist) :
        # answer.append(visited) -> visited의 주소지가 재귀 안에서 공유되어 모든 answer의 원소가 같은 값이 되는 문제 발생.
        answer.append(visited.copy())
        return answer
    for m in mylist :
        if m in visited : continue
        visited.append(m)
        answer = dfs(mylist, visited, answer)
        visited.pop()
    return answer

<< 알고리즘 모식도 첨부 예정 >>


2. 반복문, 인덱싱, 스위칭

def permute(arr):
    result = [arr[:]]
    c = [0] * len(arr)
    i = 0
    while i < len(arr):
        if c[i] < i:
            if i % 2 == 0:
                arr[0], arr[i] = arr[i], arr[0]
            else:
                arr[c[i]], arr[i] = arr[i], arr[c[i]]
            result.append(arr[:])
            c[i] += 1
            i = 0
        else:
            c[i] = 0
            i += 1
    return result

3. itertools 라이브러리 .permutation

import itertools

pool = ['A', 'B', 'C']
print(list(map(''.join, itertools.permutations(pool)))) # 3개의 원소로 순열 만들기
print(list(map(''.join, itertools.permutations(pool, 2)))) # 2개의 원소로 순열 만들기

'Algorithem' 카테고리의 다른 글

최장 증가 부분 수열 (LIS) : 수열 길이마다 최대값 갱신  (0) 2023.01.05
거대한 피보나치 수열 : 행렬 곱으로 표현하기  (0) 2023.01.05
n, m 수열 만들기  (0) 2023.01.05
Union Find 와 서로소 집합(Disjoint Set)  (0) 2023.01.05
알고리즘의 이해  (0) 2023.01.05
'Algorithem' 카테고리의 다른 글
  • 거대한 피보나치 수열 : 행렬 곱으로 표현하기
  • n, m 수열 만들기
  • Union Find 와 서로소 집합(Disjoint Set)
  • 알고리즘의 이해
jamong5
jamong5
데이터 엔지니어를 희망하는 개발자 지망생
jamong5
JAMONG5
jamong5
전체
오늘
어제
  • 분류 전체보기 (171)
    • Algorithem (92)
      • 백준 PS with code (64)
      • 프로그래머스 PS with code (9)
      • 알고리즘 이론 (3)
    • Languages (19)
      • Python (10)
      • Java (2)
      • C & C++ (7)
    • SQL (42)
      • 프로그래머스 MySQL with code (41)
      • MySQL (1)
    • CS (2)
    • DevOps (4)
      • Docker (1)
      • Git, GitHub (3)
    • 코드 고민 (1)
    • 도움을 받은 정보 (2)
    • 책 (4)
    • 보드 게임 일기 (1)
    • 컴퓨터 일기 (2)
    • R&D 휴지통 (0)

블로그 메뉴

  • 소개
  • 홈
  • 태그

공지사항

인기 글

태그

  • 백트래킹
  • 백준
  • 시간초과
  • 똥이
  • 알고리즘
  • MySQL
  • LCS
  • 그래프탐색
  • 투포인터
  • Python
  • Git
  • 최소힙
  • 스택
  • join
  • 구현
  • SQL
  • 프로그래머스
  • 파이썬
  • heapq
  • backtracking

최근 댓글

최근 글

hELLO · Designed By 정상우.
jamong5
순열 찾기 (python code)
상단으로

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.