PAT乙 1028 人口普查 (GO语言)

博客介绍了PAT乙1028题的解题思路。第3个测试点较坑,若所有输入都不符合,有效个数为0则直接输出0。解题时可直接用字符串比较,无需拆分年月。定义最年轻和最年长时间,每次输入合适的就替换。GO语言实现用bufio输入可避免超时。

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

解题思路:
第3个测试点错误,这个比较坑,存在所有的输入都是不符合,有效个数为0,直接输出0即可
1.直接用字符串比较,不需要把后面的字符串再拆分成年月日
2.因为这题有时间区间,首先定义最年轻的1814/09/06,最年长的2014/09/06
3.接下去,每一次输入都比较一下,合适的就替换年轻/年长。
4.GO实现需要用bufio输入,不会超时

package main

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

type Birthday struct {
	name string
	birth string
}

func  main() {
	var n int
	var young, old Birthday
	var inputReader *bufio.Reader
	inputReader = bufio.NewReader(os.Stdin)

	_, _ = fmt.Scanf("%d", &n)

	start := "1814/09/06"
	end := "2014/09/06"
	young.birth = start
	old.birth = end
	m:=0
	for i:=0; i<n; i++ {
		str, _ := inputReader.ReadString('\n')
		strArray := strings.Fields(str)
		name := strArray[0]
		birth := strArray[1]
		if birth <= end && birth >= start {
			m++
			if birth > young.birth {
				young.name = name
				young.birth = birth
			}
			if birth < old.birth {
				old.name = name
				old.birth = birth
			}
		}
	}
	if m == 0 {
		fmt.Printf("%d\n", m)
	} else {
		fmt.Printf("%d %s %s\n", m, old.name, young.name)
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值