题解 | #小红的树#

小红的树

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])
    }
}

全部评论

相关推荐

03-12 15:35
嘉应学院 Python
快说谢谢牛牛精灵:说不定就是下一个寒武纪!
点赞 评论 收藏
分享
03-14 16:04
已编辑
安徽农业大学 算法工程师
痴心的她allin秋...:啥笔试都挂怎么办,某9本考研下岸,练也没时间了,对算法也不感兴趣,大部分大厂笔试只能A0-1个😄
米哈游笔试
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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