题解 | #小红的树#

小红的树

https://www.nowcoder.com/practice/66ab364d3fba487eb39bd3460fd484c0

package main

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

var in = bufio.NewReader(os.Stdin)
var out = bufio.NewWriter(os.Stdout)

func readAlpha(b *byte) error {
	c, err := in.ReadByte()
	for ; err == nil && (c < 'A' || c > 'Z'); c, err = in.ReadByte() {
	}
	for ; err == nil && c >= 'A' && c <= 'Z'; c, err = in.ReadByte() {
		*b = c
		return nil
	}
	return err
}

func readInt(b *int) error {
    ans, read := 0, false
	c, err := in.ReadByte()
	for ; err == nil && (c < '0' || c > '9'); c, err = in.ReadByte() {
	}
	for ; err == nil && c >= '0' && c <= '9'; c, err = in.ReadByte() {
		ans = ans *10 + int(c-'0')
		read = true
	}
    if read {
        *b = ans
        return nil
    }
	return err
}
func main() {
    defer out.Flush()
	var n, q int
    readInt(&n)
    var edge = make([][]int, n+1)
    var dp = make([]int, n+1)
    var cost = make([]int, n+1)
    for i := 2; i <= n; i++ {
        var fa int
        readInt(&fa)
        edge[fa] = append(edge[fa], i)
    }
    for i:= 1; i <= n; i++ {
        var c byte
        readAlpha(&c)
        if c == 'R' {
            cost[i] =1
        }
    }
    var dfs func(int, int)
    dfs = func(root, fa int) {
        dp[root] = cost[root]
        for _, item := range edge[root] {
            if item == fa {
                continue
            }
            dfs(item, root)
            dp[root] += dp[item]
        }
    }
    dfs(1, -1)
    readInt(&q)
    for i := 0; i < q; i++ {
        var val int
        readInt(&val)
        fmt.Fprintln(out, dp[val])
    }
}

全部评论

相关推荐

叶扰云倾:进度更新,现在阿里云面完3面了,感觉3面答得还行,基本都答上了,自己熟悉的地方也说的比较细致,但感觉面试官有点心不在焉不知道是不是不想要我了,求阿里收留,我直接秒到岗当阿里孝子,学校那边的房子都退租了,下学期都不回学校,全职猛猛实习半年。这种条件还不诱人吗难道 然后现在约到了字节的一面和淘天的复活赛,外加猿辅导。华为笔试完没动静。 美团那边之前投了个base广州的,把我流程卡麻了,应该是不怎么招人,我直接简历挂了,现在进了一个正常的后端流程,还在筛选,不知道还有没有hc。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务