[Python] 리스트(2)Language/Python2022. 12. 6. 03:35
Table of Contents
이전 리스트에 관한 글을 읽고 싶다면
2022.12.06 - [Language/Python] - [Python] 리스트(1)
리스트 합병, 복제, 비교
리스트의 합병 및 복제
+연산자를 활용하여 2개의 리스트를 하나로 합병 가능
heroes1 = [ "아이언맨", "토르" ] heroes2 = [ "헐크", "스칼렛 위치" ] avengers = heroes1 + heroes2 # avengers는 ['아이언맨', '토르', '헐크', '스칼렛 위치']가 됨
*연산자를 활용하여 복제 후 합병 가능numbers = [ 1, 2, 3, 4 ] * 3 # 리스트는 [1, 2, 3, 4, 1, 2, 3, 4, 1, 2, 3, 4]
리스트 초기화에 활용numbers = [ 0 ] * 12 # 리스트는 [0,0,0,0,0,0,0,0,0,0,0,0]
리스트 비교
비교 연산자 == , !=, >, < 를 사용하여 리스트 간 비교 가능
list1 = [ 1, 2, 3 ] list2 = [ 1, 2, 3 ] print(list1 == list2) #True list1 = [ 3, 4, 5 ] list2 = [ 1, 2, 3 ] print(list1 > list2) #첫번째 인덱스만 비교함 #출력 결과는 True for i in range(3): #모든 인덱스 비교 print(list1[i] > list2[i]) #출력 결과는 #False #False #False
리스트 복사 : 얕은 복사(shallow copy)
temps = [28, 31, 33, 35, 27, 26, 25]
values = temps
temps: temps리스트의 시작항목의 주소
values: temps리스트의 시작항목의 주소
temps, values 둘 다 같은 공간을 참조하고 있음
temps = [28, 31, 33, 35, 27, 26, 25]
values = temps #얕은 복사 (shallow copy)
print(temps)
values[3] = 39
print(temps)
#[28, 31, 33, 35, 27, 26, 25]
#[28, 31, 33, 39, 27, 26, 25]
둘 다 같은 공간을 참조하기 때문에 한 쪽만 값을 바뀌어도 둘 다 값이 바뀌게 된다.
리스트 복사 : 깊은 복사(deep copy)
temps = [28, 31, 33, 35, 27, 26, 25]
values = list(temps) #복사 생성자 활용
list의 복사 생성자를 활용하면 깊은 복사를 할 수 있다.
이렇게 하면 한 공간을 참조하지 않기 때문에 한쪽 값을 바꾸어도 다른 쪽은 영향을 받지 않는다.
슬라이싱
기본 슬라이싱
슬라이싱이란 리스트에서 한 번에 여러 개의 항목을 추출하는 기법이다.
리스트[start : stop]
numbers = [10, 20, 30, 40, 50, 60, 70, 80, 90]
sublist = numbers[2:7]
2번째 인덱스(30) 에서 6번째 인덱스까지(70)([2:7]에서 7은 포함하지 않는다) 추출한다는 뜻이다
시작과 끝 인덱스는 생략이 가능하다
numbers= [10,20,30,40,50,60,70,80,90]
numbers[:3] # [10, 20, 30]
numbers[3:] # [40, 50, 60, 70, 80, 90]
numbers[:] # [10, 20, 30, 40, 50, 60, 70, 80, 90]
깊은 복사의 또 다른 방법
new_numbers = numbers[:]
고급 슬라이싱
슬라이싱을 할 때 단계 지정이 가능
리스트[start:stop:step]
numbers= [10,20,30,40,50,60,70,80,90]
numbers[2:7:2] # [30, 50, 70]
음수 단계를 사용하여 리스트 역순화
numbers = [ 10, 20, 30, 40, 50, 60, 70, 80, 90 ] numbers[:: -1] #[90, 80, 70, 60, 50, 40, 30, 20, 10]
리스트 변경lst = [1, 2, 3, 4, 5, 6, 7, 8] lst[0:3] = ['white', 'blue', 'red'] #lst : ['white', 'blue', 'red', 4, 5, 6, 7, 8]
lst = [1, 2, 3, 4, 5, 6, 7, 8] lst[:] = [ ] #lst : []
lst = [1, 2, 3, 4, 5, 6, 7, 8] del lst[0:2] lst : [3, 4, 5, 6, 7, 8]
파이썬에서 문자열은 문자들이 모여있는 리스트이다.
s = "Monty Python" print(s[0]) #M print(s[6:10]) #Path print(s[-12:-7]) #Monty
2차원 리스트
2차원 리스트란
2차원 리스트는 1차원 리스트가 행과 열을 이루어 모여있는 것
정적 할당 2차원 리스트
2차원 리스트 구현(정적 할당)
-각각의 행들이 하나의 리스트 형태로 저장
-각각의 행에 대한 레퍼런스(주소)가 하나의 리스트 형태로 저장
s = [ [ 1, 2, 3, 4, 5 ] , [ 6, 7, 8, 9, 10 ], [11, 12, 13, 14, 15 ] ]
동적 할당 2차원 리스트
2차원 리스트의 동적 할당
rows = 3 cols = 5 s = [ ] for row in range(rows): s += [[0]*cols] # 1차원 리스트끼리 순차적으로 합쳐짐 print("s =", s) # [[0, 0, 0, 0, 0], [0, 0, 0, 0, 0], [0, 0, 0, 0, 0]]
2차원 리스트 요소 접근
s = [[ 1, 2, 3, 4, 5 ] ,[ 6, 7, 8, 9, 10 ], [11, 12, 13, 14, 15 ] ] print(s[1][1]) #7 print(s[2][1]) #12 #7 #12
2차원 리스트의 구현
s = [[ 1, 2, 3, 4, 5 ] ,[ 6, 7, 8, 9, 10 ], [11, 12, 13, 14, 15 ] ]
rows = len(s)
cols = len(s[0])
for r in range(rows):
for c in range(cols):
print(s[r][c], end=",")
print( )
출력결과
리스트와 함수
일반적 프로그래밍 언어에서 함수의 인수 전달 방식
값으로 호출 (call by value)
참조로 호출 (call by reference)
불변 객체(int, float, tuple, string등)
파이썬에서는?
불변 객체(int, float, tuple, string등) :
객체의 참조값이 함수의 매개 변수로 전달되지만
함수 안에서 객체의 값을 변경하면 새로운 객체가 생성 (call by value형태)
가변 객체 (리스트)
가변 객체 (리스트) :
참조값으로 전달되며, 함수 내에서 리스트의 변경이 가능 (call by reference)
2차원 리스트를 함수로 넘기기
2차원 배열의 총 합을 구하는 함수
def sum(numbers) :
total = 0
for i in range(len(numbers)) :
for j in range(len(numbers[0])) :
total = total + numbers[i][j]
return total
s = [[ 1, 2, 3, 4, 5 ] ,[ 6, 7, 8, 9, 10 ], [11, 12, 13, 14, 15 ] ]
print(sum(s))
출력 결과 : 120
'Language > Python' 카테고리의 다른 글
[Python] 문자열 (1) | 2022.12.08 |
---|---|
[Python] 딕셔너리 (0) | 2022.12.07 |
[Python] 세트 (0) | 2022.12.07 |
[Python] 튜플 (0) | 2022.12.06 |
[Python] 리스트(1) (0) | 2022.12.06 |