首页 > 8.21 网易通用技术A卷笔试情况统计+AK参考代码
头像
LifeAndDonuts
发布于 2021-08-21 17:34
+ 关注

8.21 网易通用技术A卷笔试情况统计+AK参考代码

[ 编程 |20分 ] 数组中两个元素和小于等于M的组合数
时间限制:C/C++ 1秒,其他语言 2秒
空间限制:C/C++ 262144K,其他语言 524288K
64bit IO Format: %lld
本题可使用本地IDE编码,不能使用本地已有代码,无跳出限制,编码后请点击“保存并调试”按钮进行代码提交。

题目描述

对于一个整型数组,里面任何2个元素相加,小于等于M的组合有多少种;
如果有符合的,输出组合对数;
没有,输出0;

输入描述:

输入有2行,第1行为int整型数组,第2行为M值,且M也为int整型数字
比如:
7 -1 -1
9
表示数组为[7, -1, -1],M=9

输出描述:

里面任何两个元素小于等于9的组合有3种,分别是(7,第2个元素 -1), (第2个元素 -1, 第3个元素 -1), (7, 第3个元素 -1),不同位置相同的元素值,但可以组成不同的组合
故输出为 3
示例1输入输出示例仅供调试,后台判题数据一般不包含示例

输入

7 -1 -1
                                    9

输出

3

说明

输入:数组为[7, -1, -1],M=9
输出:3

参考代码

import sys
from bisect import bisect_right

readline = sys.stdin.readline

nums = list(map(int, readline().strip().split()))
M = int(readline().strip())

nums.sort()
ans = 0

for i, x in enumerate(nums):
    ans += bisect_right(nums[:i], M - x)

print(ans)
[ 编程 |30分 ] 计算K位
时间限制:C/C++ 1秒,其他语言 2秒
空间限制:C/C++ 65536K,其他语言 131072K
64bit IO Format: %lld
语言限定:C++(clang++11), Java(javac 1.8), C(clang11), Python2(2.7.3), Python3(3.9), C#(mcs 5.4), PHP(7.4.7), JavaScript Node(12.18.2), Go(1.14.4), Ruby(2.7.1), Rust(1.44), Swift(5.3), Scala(2.11.12), Kotlin(1.4.10), Groovy(3.0.6), TypeScript(4.1.2)
本题可使用本地IDE编码,不能使用本地已有代码,无跳出限制,编码后请点击“保存并调试”按钮进行代码提交。

题目描述

给你两个正整数 n 和 k,其中 1 =< n <= 26,字符串  Sn 的形成规则如下:

Li表示26个字母a-z,依次是:
L1 =  "a"
L2 =  "b"
L3 = "c"
...
L26="z"

S1 = "a"
当 i > 1 时,Si = Si-1 +Li + reverse(invert(Si-1))
其中 + 表示字符串的连接操作,reverse(x) 返回反转 x 后得到的字符串,而 invert(x) 则会翻转 x 中的每一位(例如:`a` 翻转为 `z` ,`b`  翻转为 `y` , ... 而 `z` 翻转为 `a`)。

例如,符合上述描述的序列的前 4 个字符串依次是:

S1="a"
S2="abz"
S3="abzcayz"
S4="abzcayzdabzxayz"

请你返回  Sn 的 第 k 位字符 ,题目数据保证 k 一定在 Sn 长度范围以内。
示例1输入输出示例仅供调试,后台判题数据一般不包含示例

输入

3,1

输出

a

说明

S3为 "abzcayz",其第 1 位为 "a" 。
示例2输入输出示例仅供调试,后台判题数据一般不包含示例

输入

4,11

输出

z

说明

S4为 "abzcayzdabzxayz",其第 11 位为 "z" 。

参考代码

B = [0]
for i in range(1, 27):
    B.append(B[-1] * 2 + 1)


class Solution:
    def findKthBit(self, n: int, k: int) -> str:
        mid = (B[n] + 1) // 2
        if k == mid:
            return chr(n + ord("a") - 1)
        elif k < mid:
            return self.findKthBit(n - 1, k)
        return chr(
            ord("z")
            - ord(self.findKthBit(n - 1, B[n - 1] + 1 - (k - mid)))
            + ord("a")
        )


print(Solution().findKthBit(1, 1))
[ 编程 |30分 ] 纸张分配问题
时间限制:C/C++ 1秒,其他语言 2秒
空间限制:C/C++ 262144K,其他语言 524288K
64bit IO Format: %lld
本题可使用本地IDE编码,不能使用本地已有代码,无跳出限制,编码后请点击“保存并调试”按钮进行代码提交。

题目描述

一群小朋友围成一圈准备开始画画,现在老师需要给这些孩子发纸张;
规则是如果一个小朋友的年龄比自己旁边的人大,那么这个小朋友就必须分到比身旁孩子更多的纸张;
所有孩子至少要有一个纸张,请帮助老师设计一个算法,算出最少需要多少张纸。
备注:
假设小朋友的总数量不会超过100个;
每个小朋友至少要求至少有一张纸;
当且仅当年龄大于相邻小朋友时,才会要求纸张数量更多(年龄相等的情况下,允许小于或者等于)。

输入描述:

输入是一个数组,表示孩子的年龄,以空格隔开,举例如下:
4 4 5
代表3个小朋友,年龄分别是4岁,4岁,5岁

输出描述:

输出是最少需要的纸张的数量,以上述的输入为例,则最少需要
1+1+2=4
共4张纸,输出结果如下即可
4
示例1输入输出示例仅供调试,后台判题数据一般不包含示例

输入

1 1 1

输出

3

说明

3个小朋友,年龄相同,每个小朋友只需发一张纸即可
示例2输入输出示例仅供调试,后台判题数据一般不包含示例

输入

1 2 3

输出

6

说明

3个小朋友,年龄分别需要 1+2+3共6张纸
示例3输入输出示例仅供调试,后台判题数据一般不包含示例

输入

5

输出

1

说明

1个小朋友,只需要1张纸即可

参考代码

            import sys from collections import deque

            readline = sys.stdin.readline
            a = list(map(int, readline().strip().split()))
            n = len(a)
            adj = [[] for _ in range(n)]
            indeg = [0] * n
            for i in range(n):
              l = (i - 1 + n) % n
              r = (i + 1) % n
              if a[i] > a[l]:
                adj[l].append(i)
                indeg[i] += 1
            q = deque()
            for i in range(n):
              if indeg[i] == 0:
                q.append(i)
                b = [1] * n
            while q:
              u = q.popleft()
              for v in adj[u]:
                b[v] = max(b[v], b[u] + 1)
                indeg[v] -= 1
                if indeg[v] == 0:
                  q.append(v)
            print(sum(b))
          
[ 编程 |20分 ] 航海探险
时间限制:C/C++ 1秒,其他语言 2秒
空间限制:C/C++ 32768K,其他语言 65536K
64bit IO Format: %lld
本题可使用本地IDE编码,不能使用本地已有代码,无跳出限制,编码后请点击“保存并调试”按钮进行代码提交。

题目描述

给你一个由 `0`(水)、`1`(陆地)和`2`(障碍物)组成的的二维网格,
再给你一个两栖交通工具,走陆地费用为1,走水路费用为2,
障碍物无法通行,请你计算从网格的起始位置行驶到最终位置的最小费用。
注意:
仅可以水平方向 和 竖直方向行驶。
如果无法到达目的地,则返回-1
另外,起始第1个位置不算,根据到达位置的属性来决定费用。
示例1输入输出示例仅供调试,后台判题数据一般不包含示例

输入

[1,1,1,1,0],[0,1,0,1,0],[1,1,2,1,1],[0,2,0,0,1]]

输出

7

说明

路径:[0,0]起,经过[0,1],[0,2],[0,3],[1,3],[2,3],[2,4],[3,4],到达终点。

参考代码

import heapq
from typing import List


class Solution:
    def minSailCost(self, g: List[List[int]]) -> int:
        n = len(g)
        m = len(g[0])
        dist = [[float("inf") for _ in range(m)] for _ in range(n)]
        dist[0][0] = 0
        q = []
        heapq.heappush(q, (0, 0))
        dx = [0, -1, 0, 1]
        dy = [-1, 0, 1, 0]
        while q:
            d, u = heapq.heappop(q)
            i, j = divmod(u, m)
            for k in range(4):
                r, c = i + dx[k], j + dy[k]
                if 0 <= r < n and 0 <= c < m and g[r][c] != 2:
                    if d + 2 - g[r][c] < dist[r][c]:
                        dist[r][c] = d + 2 - g[r][c]
                        heapq.heappush(q, (dist[r][c], r * m + c))
        if dist[-1][-1] == float("inf"):
            return -1
        return dist[-1][-1]
          

全部评论

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

推荐话题

相关热帖

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

热门推荐