원형 배열을 사용하여 Go에서 대기열을 올바르게 구현하는 방법은 무엇입니까?
Go에서 대기열을 구현하는 방법
이 질문은 원형 배열을 기본 데이터로 사용하여 Go에서 간단한 대기열의 구현을 탐구합니다. 구조. 이 접근 방식은 "컴퓨터 프로그래밍 기술"에 설명된 알고리즘을 따릅니다. 그러나 제시된 초기 코드에서는 잘못된 출력 문제가 발생했습니다.
불일치 이해
코드의 주요 문제는 오류를 처리할 메커니즘이 없다는 것입니다. 대기열이 꽉 찬 상황입니다. 원형 어레이 접근 방식에는 용량이 언제 확보되는지 확인할 수 있는 방법이 필요합니다. 원본 코드에는 이 검사가 부족하여 배열 끝을 넘어서 요소를 덮어쓰려고 했습니다.
구현 개선
이 문제를 해결하려면 간단한 수정을 하면 됩니다. 소개됩니다. Enqueue 함수에는 이제 tail 인덱스가 head 인덱스와 같지 않은지 확인하는 조건이 포함됩니다. 동일하면 대기열이 가득 차고 함수는 false를 반환합니다. 그렇지 않으면 대기열에 요소를 추가하고 tail 인덱스를 증가시킨 후 true를 반환합니다.
개선된 코드
업데이트된 코드는 다음과 같습니다.
package main import ( "fmt" ) type Queue struct { len int head, tail int q []int } func New(n int) *Queue { return &Queue{n, 0, 0, make([]int, n)} } func (p *Queue) Enqueue(x int) bool { p.q[p.tail] = x ntail := (p.tail + 1) % p.len if ntail != p.head { p.tail = ntail return true } return false } func (p *Queue) Dequeue() (int, bool) { if p.head == p.tail { return 0, false } x := p.q[p.head] p.head = (p.head + 1) % p.len return x, true } func main() { q := New(10) for i := 1; i < 13; i++ { fmt.Println(i, q.Enqueue(i)) } fmt.Println() for i := 1; i < 13; i++ { fmt.Println(q.Dequeue()) } }
이 수정을 통해 코드는 대기열에 넣기 및 대기열에서 빼기 요소를 올바르게 처리하여 예상되는 결과를 얻습니다. 출력:
1 true 2 true 3 true 4 true 5 true 6 true 7 true 8 true 9 true 10 true 11 true 12 true 11 true 12 true 1 true 2 true 3 true 4 true 5 true 6 true 7 true 8 true 9 true 10 true
위 내용은 원형 배열을 사용하여 Go에서 대기열을 올바르게 구현하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

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

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

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

Clothoff.io
AI 옷 제거제

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

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

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

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

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











Go Language Pack 가져 오기 : 밑줄과 밑줄이없는 밑줄의 차이점은 무엇입니까?

Beego 프레임 워크에서 페이지간에 단기 정보 전송을 구현하는 방법은 무엇입니까?

MySQL 쿼리 결과 목록을 GO 언어로 사용자 정의 구조 슬라이스로 변환하는 방법은 무엇입니까?

GO에서 제네릭에 대한 사용자 정의 유형 제약 조건을 어떻게 정의 할 수 있습니까?

이동 중에 테스트를 위해 모의 개체와 스터브를 작성하려면 어떻게합니까?

추적 도구를 사용하여 GO 응용 프로그램의 실행 흐름을 이해하려면 어떻게해야합니까?
