개발 과정에서 큐는 매우 실용적인 데이터 구조입니다. 대기열을 사용할 때 반복 대기열을 구현하는 방법과 같은 몇 가지 문제가 발생할 수 있습니다.
많은 시나리오에서 대기열에 요소를 추가해야 하지만 해당 요소가 이미 대기열에 있는 경우 중복 요소 추가를 피하기 위해 해당 요소를 무시해야 합니다. 이때는 중복되지 않는 대기열을 사용해야 합니다.
Golang에서는 맵을 사용하여 중복되지 않는 대기열을 구현할 수 있습니다. 구체적으로 요소를 맵에 키로 넣을 수 있으며 값은 true 또는 다른 값으로 설정할 수 있습니다. 키가 맵에 이미 존재하는 경우 이를 무시할 수 있습니다. 그렇지 않으면 요소를 대기열에 추가할 수 있습니다.
다음은 중복되지 않는 대기열을 구현하기 위해 맵을 사용하는 샘플 코드입니다.
type uniqueQueue struct { items map[string]bool queue []string } func newUniqueQueue() *uniqueQueue { return &uniqueQueue{ items: make(map[string]bool), queue: []string{}, } } func (q *uniqueQueue) enqueue(item string) { if !q.items[item] { q.items[item] = true q.queue = append(q.queue, item) } } func (q *uniqueQueue) dequeue() string { item := q.queue[0] q.queue = q.queue[1:] delete(q.items, item) return item } func (q *uniqueQueue) isEmpty() bool { return len(q.queue) == 0 }
위 코드에서는 items
를 포함하는 uniqueQueue
라는 유형을 정의합니다. 코드 맵> 및 큐
배열. items
는 대기열에 이미 존재하는 요소를 저장하는 데 사용되며, queue
는 대기열에 있는 요소의 순서를 저장하는 데 사용됩니다. uniqueQueue
的类型,它包含了一个 items
的 map 和一个 queue
的数组。items
用来保存队列中已经存在的元素,而 queue
用来保存队列中的元素顺序。
我们在 enqueue
方法中实现了向队列中添加元素的功能。在添加元素的时候,我们首先需要判断该元素是否存在于 items
中。如果不存在,我们可以将元素添加到 queue
中,并将 items
中该元素对应的值设置为 true。否则,我们就需要忽略该元素。
在 dequeue
方法中,我们实现了从队列中移除元素的功能。具体来说,我们从队列的第一个元素开始移除,并将 items
中该元素删除。最后,我们返回移除的元素。
在 isEmpty
enqueue
메소드에서 큐에 요소를 추가하는 기능을 구현합니다. 요소를 추가할 때 먼저 해당 요소가 items
에 존재하는지 확인해야 합니다. 존재하지 않는 경우 queue
에 요소를 추가하고 items
에 있는 요소의 해당 값을 true로 설정할 수 있습니다. 그렇지 않으면 요소를 무시해야 합니다. dequeue
메소드에서는 큐에서 요소를 제거하는 기능을 구현합니다. 특히 대기열에서 첫 번째 요소를 제거하고 항목
에서 해당 요소를 삭제합니다. 마지막으로 제거된 요소를 반환합니다. 🎜🎜isEmpty
메서드에서는 대기열이 비어 있는지 확인합니다. 이 메서드는 대기열에 요소가 없으면 true를 반환합니다. 🎜🎜위 코드를 사용하면 중복되지 않은 대기열을 쉽게 구현할 수 있고 중복 요소의 출현을 피할 수 있으므로 코드의 효율성과 성능이 향상됩니다. 🎜위 내용은 golang은 대기열을 반복하지 않습니다의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

이 기사에서는 GO의 패키지 가져 오기 메커니즘을 설명합니다. 명명 된 수입 (예 : 가져 오기 & quot; fmt & quot;) 및 빈 가져 오기 (예 : import _ & quot; fmt & quot;). 명명 된 가져 오기는 패키지 내용을 액세스 할 수있게하고 빈 수입은 t 만 실행합니다.

이 기사에서는 MySQL 쿼리 결과를 GO 구조 슬라이스로 효율적으로 변환합니다. 수동 구문 분석을 피하고 최적의 성능을 위해 데이터베이스/SQL의 스캔 방법을 사용하는 것을 강조합니다. DB 태그 및 Robus를 사용한 구조물 필드 매핑에 대한 모범 사례

이 기사에서는 웹 애플리케이션에서 페이지 간 데이터 전송에 대한 Beego의 NewFlash () 기능을 설명합니다. NewFlash ()를 사용하여 컨트롤러간에 임시 메시지 (성공, 오류, 경고)를 표시하여 세션 메커니즘을 활용하는 데 중점을 둡니다. 한계

이 기사는 단위 테스트를 위해 이동 중에 모의와 스터브를 만드는 것을 보여줍니다. 인터페이스 사용을 강조하고 모의 구현의 예를 제공하며 모의 집중 유지 및 어설 션 라이브러리 사용과 같은 모범 사례에 대해 설명합니다. 기사

이 기사에서는 GO의 제네릭에 대한 사용자 정의 유형 제약 조건을 살펴 봅니다. 인터페이스가 일반 함수에 대한 최소 유형 요구 사항을 정의하여 유형 안전 및 코드 재사성을 향상시키는 방법에 대해 자세히 설명합니다. 이 기사는 또한 한계와 모범 사례에 대해 설명합니다

이 기사는 OS.WriteFile (작은 파일에 적합)과 OS.OpenFile 및 Buffered Writes (큰 파일에 최적)를 비교하여 효율적인 파일 쓰기를 자세히 설명합니다. 강력한 오류 처리, 연기 사용 및 특정 오류 확인을 강조합니다.

이 기사는 GO에서 단위 테스트 작성, 모범 사례, 조롱 기술 및 효율적인 테스트 관리를위한 도구를 다루는 것에 대해 논의합니다.

이 기사는 추적 도구를 사용하여 GO 응용 프로그램 실행 흐름을 분석합니다. 수동 및 자동 계측 기술, Jaeger, Zipkin 및 OpenTelemetry와 같은 도구 비교 및 효과적인 데이터 시각화를 강조합니다.


핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

AI Hentai Generator
AI Hentai를 무료로 생성하십시오.

인기 기사

뜨거운 도구

드림위버 CS6
시각적 웹 개발 도구

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

Eclipse용 SAP NetWeaver 서버 어댑터
Eclipse를 SAP NetWeaver 애플리케이션 서버와 통합합니다.

mPDF
mPDF는 UTF-8로 인코딩된 HTML에서 PDF 파일을 생성할 수 있는 PHP 라이브러리입니다. 원저자인 Ian Back은 자신의 웹 사이트에서 "즉시" PDF 파일을 출력하고 다양한 언어를 처리하기 위해 mPDF를 작성했습니다. HTML2FPDF와 같은 원본 스크립트보다 유니코드 글꼴을 사용할 때 속도가 느리고 더 큰 파일을 생성하지만 CSS 스타일 등을 지원하고 많은 개선 사항이 있습니다. RTL(아랍어, 히브리어), CJK(중국어, 일본어, 한국어)를 포함한 거의 모든 언어를 지원합니다. 중첩된 블록 수준 요소(예: P, DIV)를 지원합니다.

Atom Editor Mac 버전 다운로드
가장 인기 있는 오픈 소스 편집기
