supergravity

파이썬 기본 본문

개발중 기억해야 할만한 것들/파이썬

파이썬 기본

supergravity 2021. 3. 7. 18:52

수 자료형

 

수 자료형 대하여 사칙연산과 나머지 연산자가 많이 사용됩니다.

단 나누기(/)를 주의해서 사용해야 합니다.

    파이썬에서 나누기 연산자(/)는 나눠진 결과를 실수형으로 반환합니다.

다양한 로직을 설계할 때 나머지 연산자(%)를 이용해야 할 때가 많습니다.

    예시: a가 홀수인지 체크해야 하는 경우

파이썬에서는 몫을 얻기 위해 몫 연산자를(//) 사용합니다.

이외에도 거듭 제곱 연산자(**)를 비롯해 다양한 연산자들이 존재합니다.

 

a = 7
b = 3

#나누기

a / b

#나머지

a % b

#몫

a // b

#거듭 제곱

a**b

 

리스트 자료형

 

여러 개의 데이터를 연속적으로 담아 처리하기 위해 사용하는 자료형입니다.

    사용자 입방에서 C나 자바에서의 배열(Array)의 기능 및 연결 리스트와 유사한 지원합니다.

    리스트 대신에 배열 혹은 테이블이라고 부르기도 합니다/

 

리스트는 대괄호([ ])안에 원소를 넣어 초기화하며, 쉼표(,)로 원소를 구분합니다.

비어 있는 리스트를 선언하고자 할 때는 list() 혹은 간단히 []를 이용할수 있습니다.

리스트의 원소를 접근할 때는 인덱스(Index) 값을 괄호에 넣습니다.

    인덱스는 0부터 시작합니다.

 

a = [1, 2, 3, 4, 5, 6, 7, 8, 9 ]


#네 번째 원소만 출력

a[3]

#크기가 N이고, 모든 값이 0인 1차원 리스트 초기화

n = 10
a = [0]*n

 

인덱스 값을 입력하여 리스트의 특정한 원소에 접근하는 것을 인덱싱이라고 합니다.

    파이썬의 인덱스 값은 양의 정수와 음의 정수를 모두 사용할수 있습니다.

    음의 정수를 넣으면 원소를 거꾸로 탐색하게 됩니다.

 

a = [1, 2, 3, 4, 5, 6, 7, 8, 9]


#여덟 번쨰 원소만 출력

a[7]

#뒤에서 첫 번째 원소 출력

a[-1]

#뒤에서 세 번째 원소 출력

a[-3]

#네 번째 원소 값 변경

a[3] = 7

 

리스트의 인덱싱과 슬라이싱

 

리스트에서 연속적인 위치를 갖는 원소들을 가져와야 할 때는 슬라이싱(Slicing)을 이용합니다.

    대괄호 안에 콜론(:)을 넣어서 시작 인덱스와 끝 인덱스를 설정할 수 있습니다.

    끝 인덱스는 실제 인덱스보다 1을 더 크게 설정합니다.

 

a = [1, 2, 3, 4, 5, 6 ,7 ,8 ,9 ]

#두 번째 원소부터 네 번째 원소까지
a[1:4]

 

리스트 컴프리헨션

 

리스트를 초기화하는 방법 중 하나입니다.

    대괄호 안에 조건문과 반복문을 적용하여 리스트를 초기화 할 수 있습니다.

arry = [ i for i in range(10) ]


#아래와 같은 값이 저장된다.
arrr = [0, 1, 2, 3, 4, 5, 6, 7, 8, 9]


arry = [ i for i range(20) if i % 2 ==1 ]

#아래와 같은 값이 저장된다
arrry = [1, 3, 5, 7, 9, 11, 13, 15, 17, 19]

arry = [ i*i for i in range(1, 10)]

#아래와 같은 값이 저장된다
arry = [1, 4, 9 ....]

 

리스트 컴프리헨션은 2차원 리스트를 초기화할 때 효과적으로 사용될수 있습니다.

특히 NXM 크기의 2차원 리스트를 한 번에 초기화 해야 할 떄 매우 유용합니다.

    좋은 예시 : array = [ [0]*m for _ in range(n) ] 

만약 2차원 리스트를 초기화할 때 다음과 같이 작성하면 예기치 않은 결과가 나올 수 있습니다. 

    잘못된 예시 : array = [ [0] *m ] *n

    위의 코드는 전체 리스트 안에 포함된 각 리스트가 모두 같은 객체로 인식 됩니다.

 

 

함수명 사용법 설명 시간 복잡도
append() 변수명.append() 리스트에 원소를 하나 삽입할 때 사용된다.  O(1)
sort() .sort() 오름차순으로 정렬한다.  O(NlogN)
.sort(reverse = True) 내림차순으로 정렬한다.
reverse() .reverse() 리스트의 원소의 순서를 모두 뒤집어 놓는다. O(N)
insert() .insert(삽입할 위치 인댁스, 삽입할 값) 특정한 인덱스 위치에 원소를 삽입할 때 사용한다. O(N)
count() .count(특정 값) 리스트에서 특정한 값을 가지는 데이터의 개수를 셀 떄 사용한다. O(N)
remove() .remove(특정값) 특정한 값을 갖는 원소를 제거하는데, 값을 가진 원소가 여러 개면 하나만 제거한다. O(N)

 

a = [1, 2, 3, 4, 5, 5, 5 ]
remove_set = {3, 5}

#remove_list에 포함되지 않은 값만을 저장
result = [ i for i in a if i not in remove_set ] 
Comments