Go语言读入优化

该博客介绍了Go语言的基础知识,包括常量定义、输入输出处理。文章详细讲解了如何使用bufio包进行缓冲读写,以及如何创建扫描器进行单词扫描。同时,还展示了如何读取整数和浮点数,以及如何初始化和操作整数数组。博客内容侧重于Go语言的I/O操作和基本数据类型处理。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

链接:orz

package main

import (
    "bufio"
    "fmt"
    "io"
    "os"
    "strconv"
)

const N = 20
/* ======================================================================== */
//
//
//
//                           _____   _   _   ____
//                          | ____| | \ | | |  _ \
//                          |  _|   |  \| | | | | |
//                          | |___  | |\  | | |_| |
//                          |_____| |_| \_| |____/
//
//
//
/* ============================PART1: I/O ================================== */
/* ==== G0 ===== */
const BUFSIZE = int(1e6)

var (
    ot = bufio.NewWriterSize(os.Stdout, BUFSIZE)
    in = newScanner(os.Stdin)
)

type scanner struct{ sc *bufio.Scanner }

func newScanner(input io.Reader) *scanner {
    sc := bufio.NewScanner(input)
    sc.Split(bufio.ScanWords)
    sc.Buffer(make([]byte, 1024), int(1e9))
    return &scanner{sc}
}
/* ==== G1 ===== */
func rnS() string  { in.sc.Scan(); return in.sc.Text() }
func rnI() int     { i, _ := strconv.Atoi(rnS()); return i }
func rnF() float64 { f, _ := strconv.ParseFloat(rnS(), 64); return f }

/* ==== G2 ===== */
func rsI(n int) []int {
    t := make([]int, n)
    for i := 0; i < n; i++ {
        t[i] = rnI()
    }
    return t
}
func rsF(n int) []float64 {
    t := make([]float64, n)
    for i := 0; i < n; i++ {
        t[i] = rnF()
    }
    return t
}
func rsS(n int) []string {
    t := make([]string, n)
    for i := 0; i < n; i++ {
        t[i] = rnS()
    }
    return t
}

/* ===========================PART 2: Math Func ============================  */
func max(x, y int) int {
    if x > y {
        return x
    }
    return y
}
func abs(x int) int {
    if x > 0 {
        return x
    }
    return -x
}
func min(x, y int) int {
    if x < y {
        return x
    }
    return y
}
func memset(a []int, v int) {
    if len(a) == 0 {
        return
    }
    a[0] = v
    for bp := 1; bp < len(a); bp *= 2 {
        copy(a[bp:], a[:bp])
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值