> 백엔드 개발 > Golang > bufio.Scanner 및 최적화된 숫자 변환이 Go 프로그램에서 입력 검색 속도를 어떻게 높일 수 있습니까?

bufio.Scanner 및 최적화된 숫자 변환이 Go 프로그램에서 입력 검색 속도를 어떻게 높일 수 있습니까?

Linda Hamilton
풀어 주다: 2024-12-17 17:43:11
원래의
267명이 탐색했습니다.

How Can bufio.Scanner and Optimized Number Conversion Speed Up Input Scanning in Go Programs?

더 빠른 프로그램 실행을 위한 입력 검색 속도 향상

문제 설명

주어진 코드 시도 숫자 목록을 반복하고 각 숫자가 다음과 같은지 확인하여 SPOJ 문제를 해결합니다. 상수 k로 나눌 수 있습니다. 그러나 느린 입력 스캔으로 인해 실행 시간이 초과됩니다.

해결 방법

bufio.Scanner 활용

향상하려면 입력 스캐닝 효율성을 높이려면 고속 라인별 입력 처리에 맞춰진 bufio.Scanner를 활용할 수 있습니다. 기본 fmt.Scan 대신 bufio.Scanner를 사용하여 입력 줄을 검색합니다.

숫자 변환 최적화

향상된 숫자 변환을 위해 toInt()를 도입합니다. 원시 입력 바이트에서 숫자를 직접 추출하는 함수입니다. 이렇게 하면 Scanner.Text()의 느린 변환 방법을 피하고 불필요한 문자열 생성이 제거됩니다.

toInt()는 입력 바이트를 반복하고 결과에 점진적으로 10을 곱하여 이를 달성합니다. 바이트는 UTF- 8개의 숫자 십진수 표현의 인코딩된 시퀀스.

코드 스니펫

아래 수정된 코드 스니펫에는 이러한 최적화가 포함되어 있습니다.

package main

import (
    "bufio"
    "fmt"
    "os"
)

func main() {
    var n, k, c int
    scanner := bufio.NewScanner(os.Stdin)

    scanner.Scan()
    fmt.Sscanf(scanner.Text(), "%d %d", &n, &k)

    for ;n > 0; n-- {
        scanner.Scan()
        if toInt(scanner.Bytes())%k == 0 {
            c++
        }
    }

    fmt.Println(c)
}

func toInt(buf []byte) (n int) {
    for _, v := range buf {
        n = n*10 + int(v-'0')
    }
    return
}
로그인 후 복사

추가 참고 사항

이 최적화된 솔루션은 이전 방법과 비교한 실행 속도. 초기 입력 후 n 줄이 있다는 것을 포함하여 유효한 입력을 가정합니다.

닫힌 입력과 관련된 시나리오의 경우 단순화된 for 루프를 사용할 수 있습니다.

for scanner.Scan() {
    if toInt(scanner.Bytes())%k == 0 {
        c++
    }
}
로그인 후 복사

위 내용은 bufio.Scanner 및 최적화된 숫자 변환이 Go 프로그램에서 입력 검색 속도를 어떻게 높일 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿