Go 프로그래밍에서 고유 문자열만 포함하는 배열을 생성하는 것은 어려운 일입니다. 그러나 데이터 구조의 조합을 사용하여 이를 달성하는 효과적인 방법이 있습니다.
Go 언어는 내장된 집합 데이터 유형을 제공하지 않지만 지도는 효과적으로 하나의 역할을 할 수 있습니다. 맵의 키는 본질적으로 고유하므로 맵에 추가된 각 문자열이 고유함을 보장합니다. 이 접근 방식은 효율적이고 간단한 집합 구현을 생성합니다.
다음 코드 조각을 고려하세요.
m := make(map[string]bool) m["aaa"] = true m["bbb"] = true m["ccc"] = true
이 코드에서는 m이라는 맵을 생성하고 세 개의 고유 문자열을 키로 추가합니다. 특정 문자열이 집합에 존재하는지 확인하려면 간단히 인덱스 표현식을 사용하면 됩니다.
exists := m["somevalue"]
문자열이 집합에 있으면 존재 변수는 true가 됩니다. 그렇지 않으면 거짓이 됩니다.
집합의 요소 순서를 유지하는 것이 필수라면 좀 더 발전된 접근 방식이 필요합니다. 삽입 순서를 호출하는 슬라이스를 맵과 결합하여 고유성을 보장함으로써 효과적으로 정렬된 세트를 생성할 수 있습니다.
var m = make(map[string]bool) var a = []string{} func main() { add("aaa") add("bbb") add("ccc") } func add(s string) { if m[s] { return // Already in the map } a = append(a, s) m[s] = true }
이 코드에서 슬라이스 a는 추가된 순서대로 요소를 저장합니다. add 함수는 맵에서 중복 항목을 확인하고, 아무것도 발견되지 않으면 새 문자열을 슬라이스에 추가하고 그에 따라 맵을 업데이트합니다.
이러한 방법을 사용하면 문자열 배열 또는 집합을 효과적으로 생성할 수 있습니다. 요소의 우선순위 여부에 관계없이 고유한 값만 포함합니다.
위 내용은 Go에서 고유한 문자열 배열을 어떻게 만들 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!