티스토리 뷰
일반 컬렉션
- 많은 데이터를 묶어서 저장하고, 관리할 수 있는 타입
- 잘못된 값을 실수로 컬렉션형에 삽입할 수 없다.
- → 컬렉션 내부에 있는 값은 신뢰할 수 있다.
- 배열, 세트, 딕셔너리가 존재한다.
- var로 선언한다면 원소 생성, 삭제, 변경이 가능하다. (let은 불가능)
- 변경할 필요가 없다면 상수(let)으로 선언하는 것이 좋다.
- → 컴파일러가 컬렉션의 성능을 최적화하기 때문
세트 (Set)
- 같은 타입의 데이터를 순서 없이 하나의 묶음으로 저장하는 형태의 컬렉션 타입
- 순서가 중요하지 않거나, 각 요소가 유일한 값이어야하는 경우에 사용(해시 가능한 값)
- 집합관계 표현이 용이하다. (교집합, 합집합 등)
코드
// 빈 세트 생성
var animals: Set<String> = Set<String>()
var fruites: Set<String> = []
// 생성 및 초기화
var drinks: Set<String> = ["water", "coffee", "juice"]
// 타입추론은 불가능하다. (배열과 동일하게 대괄호를 사용하므로)
var letters = ["a", "b", "c"]
print(type(of:letters)) // Array<String>
// 원소 삽입
drinks.insert("coke")
drinks.insert("coke") // 에러는 나지 않지만, 요소에 추가되지 않음(중복 불허)
// 원소 삭제
drinks.remove("coke")
let oddDigit: Set<Int> = [1, 3, 5, 7, 9]
let evenDigit: Set<Int> = [0, 2, 4, 6, 8]
let primeNumber: Set<Int> = [2, 3, 5, 7]
// 합집합 연산
print(oddDigit.union(evenDigit).sorted())
// 교집합
print(oddDigit.intersection(evenDigit)) // []
// 차집합
print(oddDigit.subtracting(primeNumber).sorted()) // odd - prime
// 대칭차집합 (합집합 - 교집합)
print(oddDigit.symmetricDifference(primeNumber).sorted()) // 1, 2, 9
/*
기타연산 (Bool 형)
A.isSubset(of: B) -> A가 B의 부분집합인가?
A.isSuperset(of: B) -> A가 B를 포함하는 집합인가?
A.isDisjoint(with: B) -> A와 B에 교집합이 없는가?
*/
'Swift > Swift 문법' 카테고리의 다른 글
[클로저 - 1] 클로저와 함수 (0) | 2022.12.28 |
---|---|
[중첩 타입] 중첩타입 사용 이유와 예제 (0) | 2022.12.27 |
[SwiftUI 5.7] if let 바인딩 (0) | 2022.10.11 |
[데이터 타입] 딕셔너리(Dictionary) (0) | 2022.04.02 |
[데이터 타입] 배열 (Array) (0) | 2022.03.31 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- for문
- 백준
- do while
- 이것이 코딩테스트다
- 리플릿
- 코드업
- SwiftUI
- 레플릿
- replit
- 깃
- COMMIT
- 시간초과
- ord
- CodeUp
- Swift
- 파이썬
- 코드 업
- baekjoon
- 프로그래머스
- 반복문
- 기초 100제
- 16진수 입력
- python
- 깃허브
- 정답
- CHR
- level1
- Code up
- 부르트포스
- 설명
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | ||||||
2 | 3 | 4 | 5 | 6 | 7 | 8 |
9 | 10 | 11 | 12 | 13 | 14 | 15 |
16 | 17 | 18 | 19 | 20 | 21 | 22 |
23 | 24 | 25 | 26 | 27 | 28 | 29 |
30 | 31 |
글 보관함