首页 > 【9.12】网易2021校招笔试-算法工程师 题解
头像
RogerYOng
编辑于 2020-09-12 17:26
+ 关注

【9.12】网易2021校招笔试-算法工程师 题解

4道编程题,1道问答题

编程题都是板子题
1 AC
2 AC
3 过0.6
4 AC

本菜鸡分享一下编程题的题解

第一题

题目大意

找满足条件(两个孩子节点为叶子节点)的节点的个数

解法

遍历每个节点, 是否满足条件. 时间复杂度O(N)

代码(AC)

class TreeNode:
    def __init__(self, x):
        self.id = x
        self.left = None
        self.right = None

    def is_leaf(self):
        return self.left is None and self.right is None

    def two_children_are_leaves(self):
        return (self.left is not None
                and self.left.is_leaf()) and (self.right is not None
                                              and self.right.is_leaf())


line = input()
m, n = list(map(int, line.strip().split()))

# m 点数
# n 边数

# 点 id从1开始
nodes = [None] * (m + 1)
for i in range(1, m + 1):
    nodes[i] = TreeNode(i)

for i in range(n):
    # n条边
    line = input()
    line_split = line.strip().split()
    parent = int(line_split[0])
    left_or_right = line_split[1]
    child = int(line_split[2])
    if left_or_right == 'left':
        nodes[parent].left = nodes[child]
    else:
        nodes[parent].right = nodes[child]

cnt = 0
for i in range(1, m + 1):
    if nodes[i].two_children_are_leaves():
        cnt += 1

print(cnt)

第二题

题目大意

回文子串的数量
长为1的子串,不算回文

解法

马拉车、中心扩展法都可

代码(AC)

def expand(left, right):
    global s
    global len_s
    while left >= 0 and right < len_s and s[left] == s[right]:
        left -= 1
        right += 1
    return left + 1, right - 1  # 计算长度


def solve():
    global s
    global len_s
    global cnt

    if len_s == 1:
        return 0
    if len_s == 2:
        if s[0] == s[1]:
            return 1
        else:
            return 0

    # 长度3以上
    for i in range(len_s):
        # 奇数
        odd_left, odd_right = expand(i, i)
        odd_cnt = (odd_right - odd_left) // 2
        # 偶数
        if i < len_s - 1:
            even_left, even_right = expand(i, i + 1)
            even_cnt = (even_right - even_left + 1) // 2
        else:
            even_cnt = 0

        cnt[i] = odd_cnt + even_cnt

    all_cnt = 0
    for i in range(len_s):
        all_cnt += cnt[i]

    return all_cnt


s = input()
len_s = len(s)
cnt = [0] * len_s

res = solve()
print(res)

第三题

题目大意

给一个字符串s,
求s中字符a、b、c、x、y、z的出现次数为偶数的最长子串的长度

解法

DP
只过了60%,有没有大佬给个思路

第四题

二部图最大匹配
def dfs(boy_id):
    for girl_id in girl_ids:
        if girl_id in boy_to_girl[boy_id] and (not girl_vis[girl_id]):
            girl_vis[girl_id] = True
            if girl_res[girl_id] is None || dfs(girl_res[girl_id]):
                girl_res[girl_id] = boy_id
                return True

    return False


line = input()
boy_ids = [int(_) for _ in line.strip().split()]
line = input()
girl_ids = [int(_) for _ in line.strip().split()]

n = int(input())

boy_to_girl = {}
for boy_id in boy_ids:
    boy_to_girl[boy_id] = []

girl_res = {}  # 保存这个女孩匹配的boy
for girl_id in girl_ids:
    girl_res[girl_id] = None  # None表未匹配

girl_vis = {}  # 表示是否已经被占用
for girl_id in girl_ids:
    girl_vis[girl_id] = False

for i in range(n):
    line = input()
    line_int = [int(_) for _ in line.strip().split()]
    tmp_boy_id = line_int[0]
    tmp_girl_id = line_int[1]
    boy_to_girl[tmp_boy_id].append(tmp_girl_id)

cnt = 0
for boy_id in boy_ids:
    for girl_id in girl_ids:
        girl_vis[girl_id] = False
    if dfs(boy_id):
        cnt += 1

print(cnt)




全部评论

(2) 回帖
加载中...
话题 回帖

相关热帖

历年真题 真题热练榜 24小时
技术(软件)/信息技术类
查看全部

近期精华帖

热门推荐