언어/Python

파이썬 알고리즘 - 문자열로 서로 다른 단어 만들어내기(Anagram)

2017. 8. 18. 14:51

개발자 면접 트레이딩 - 파이썬 알고리즘 문제(3)

 

 


(1). 개발자 면접 트레이닝 - 두 문자열이 구성 요소가 같은지 확인(Anagram)하는 알고리즘


① 파이썬의 join, sorted, strip 함수를 활용

② 소문자로 변환 후 정렬이 핵심

③ 예를들어 elivs 는 = lives  , basic = isabc 와 같이 구성요소가 같다.

 

 

(2). 소스 코드


PYTHON

#anagram.py

import unittest


#두 문자열을 입력받아 정렬 한 후 같은 지 비교 (문자로 서로 다른 단어 만들어 내기)
def anagram(str1, str2):
    if ''.join(sorted(str1.lower())).strip() == ''.join(sorted(str2.lower())).strip(): #대문자 정렬도 가능 upper()
        return True
    else:
        return False

class anagramTest(unittest.TestCase):
    def test(self):
        self.assertTrue(anagram("elvis", "livez"))
        print(anagram("elvis", "livez"))
        self.assertTrue(anagram("basic", "is abd"))
        print(anagram("basic", "is abd"))

unittest.main()









 

(3). 소스 코드 분석


① 10 라인 : 먼저 입력받은 문자열을 소문자로 변환하여 변환 한 후 Join 함수로 변환 후에 strip으로 공백 제거

② 10 라인 : 두 문자열을 비교 후 구성 요소가 같으면 True 아니면 False

③ 19 라인 : assertTrue 단위 테스트 함수를 사용하여 실행 결과가 True가 나오는지 확인

④ 20 라인 : Print 함수로 출력


 

파이썬(Python) 으로 작성한 후 같은 코드를  Java 변환하여 작성해보면 더욱 도움이 될 것이다.

(4). 실행결과1 - 단위테스트 정상 출력(구성 요소가 같은 경우)

 

 

(5). 실행결과2 - 단위테스트 정상 출력(구성 요소가 다른 경우)

 

 



저작자표시 동일조건 (새창열림)

'언어 > Python' 카테고리의 다른 글

파이썬 알고리즘 - 문자열을 입력받아 중복단어 압축하기  (0) 2017.08.20
파이썬 알고리즘 - 공백을 %20으로 변환하기  (0) 2017.08.19
파이썬 알고리즘 - 문자열 입력받아 역(Reverse)으로 출력  (0) 2017.08.16
파이썬 알고리즘 - 문자열에 포함된 문자들이 전부 유일한지 검사  (0) 2017.08.14
파이썬(Python) 소개 및 설치하기  (1) 2017.02.19
'언어/Python' 카테고리의 다른 글
  • 파이썬 알고리즘 - 문자열을 입력받아 중복단어 압축하기
  • 파이썬 알고리즘 - 공백을 %20으로 변환하기
  • 파이썬 알고리즘 - 문자열 입력받아 역(Reverse)으로 출력
  • 파이썬 알고리즘 - 문자열에 포함된 문자들이 전부 유일한지 검사
[좋은사람]
[좋은사람]
좋은사람의 개발 노트 입니다.
[좋은사람]
좋은사람의 개발 노트
[좋은사람]
전체
오늘
어제
  • 전체보기 (189)
    • 언어 (68)
      • Java (12)
      • Python (39)
      • C# (5)
      • PHP (4)
      • Go (8)
    • OS (18)
      • Linux (7)
      • Windows 10 (5)
      • Etc (6)
    • 빅데이터 & 분석 (8)
      • R (0)
      • Machine Learning (8)
    • 네트워크 (4)
      • Etc (4)
    • 웹 프론트 (25)
      • Javascript & ECMA (8)
      • Vue (13)
      • React (4)
    • 웹 백엔드 (15)
      • Spring (3)
      • Django & Flask (7)
      • Npm & Express (5)
    • 개발도구 (18)
      • Jetbrains (3)
      • Eclipse (5)
      • Git (4)
      • Atom & VScode (6)
    • 데이터베이스 (7)
      • Oracle (2)
      • MariaDB & MySQL (2)
      • Etc (3)
    • 모바일 (6)
      • Android (3)
      • Hybrid (3)
    • 라이프 (20)
      • 여행 & 일상 (6)
      • 취미 (14)

블로그 메뉴

  • 홈으로
  • 블로그소개
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 3DS
  • Database
  • Algorithm
  • SpringSTS
  • Eclipse
  • OCR
  • 리액트
  • Anaconda
  • 머신러닝
  • 개발자 면접
  • 코딩 면접
  • Thread
  • Django
  • C#
  • npm
  • go
  • Linux
  • 이클립스
  • ubuntu
  • 미뮤
  • 인텔리j
  • 커펌
  • nodejs
  • ATOM
  • 아톰 에디터
  • javascript
  • windows10
  • 윈도우10
  • react
  • 디자인패턴
  • flask
  • CFW
  • 2DS
  • Java
  • vue.js
  • ps4
  • python
  • Git
  • php
  • centos

최근 댓글

최근 글

hELLO · Designed By 정상우.
[좋은사람]
파이썬 알고리즘 - 문자열로 서로 다른 단어 만들어내기(Anagram)
상단으로

티스토리툴바

단축키

내 블로그

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

블로그 게시글

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

모든 영역

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

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