字节跳动历年秋招笔试真题

如需获取完整资料,请点击下方链接领取《2024校招笔试真题秘籍》(实时更新中)

不收费,3人组团即可一块免费领取!限量免费10000个名额

手机端点击免费领取:https://www.nowcoder.com/link/campus_xzbs2

电脑端请扫码领取:

1、万万没想到之抓捕孔连顺

【题目描述】我叫王大锤,是一名特工。我刚刚接到任务:在字节跳动大街进行埋伏,抓捕恐怖分子孔连顺。和我一起行动的还有另外两名特工,我提议

我们在字节跳动大街的N个建筑中选定3个埋伏地点。

为了相互照应,我们决定相距最远的两名特工间的距离不超过D。

我特喵是个天才! 经过精密的计算,我们从X种可行的埋伏方案中选择了一种。这个方案万无一失,颤抖吧,孔连顺!

……

万万没想到,计划还是失败了,孔连顺化妆成小龙女,混在cosplay的队伍中逃出了字节跳动大街。只怪他的伪装太成功了,就是杨过本人来了也发现不了的!

请听题:给定N(可选作为埋伏点的建筑物数)、D(两两埋伏点直接最大的距离)以及可选建筑的坐标,计算在这次行动中,大锤的小队有多少种埋伏选择。

输入描述:

第一行包含空格分隔的两个数字 N和D(1 ≤ N ≤ 1000000; 1 ≤ D ≤ 1000000)

第二行包含N个建筑物的的位置,每个位置用一个整数(取值区间为[0, 1000000])表示,从小到大排列(将字节跳动大街看做一条数轴)

输出描述:

一个数字,表示不同埋伏方案的数量。结果可能溢出,请对 99997867 取模

输入样例1:

4 3

1 2 3 4

输出样例1:

4

PS:可选方案 (1, 2, 3), (1, 2, 4), (1, 3, 4), (2, 3, 4)

输入样例2:

5 19

1 10 20 30 50

输出样例2:

1

PS: 可选方案 (1, 10, 20)

【解题思路】

可以从左到右遍历所有位置,对于数组中第i个建筑,pos[i]是其坐标值,假设第一个特工安插在这里,计算一个最远的安全坐标值 ,X= pos[i] + D,可以通过二分查找右侧最后一个比X小的数组下标j,使得,pos[j] <= X < pos[j + 1]。这样,从i到j的这段区间,选定i点,然后任选两个点,都是合法的组合。计算一个排列组合数 C(j - i, 2)。

【参考代码】

MOD = 99997867
class Solution(object):
    def calc(self, N, D, positions):
        count = 0
        for i in range(N):
            # binary search
            X = positions[i] + D
            low = i + 1
            high = N - 1
            j = -1
            while low <= high:
                mid = low + (high - low) // 2
                if positions[mid] > X:
                    high = mid - 1
                else:
                    low = mid + 1
            j = high
            if (j - i - 1) > 0:
                a = (j - i) % MOD
                b = (j - i - 1) % MOD
                count += (a * b) // 2
        return count % MOD


import fileinput
s = Solution()
it = fileinput.input()
rs = next(it).split()
N = int(rs[0])
D = int(rs[1])
rs = next(it).split()
positions = [int(x) for x in rs]
print(s.calc(N, D, positions))

2、毕业旅行

【题目描述】小明目前在做一份毕业旅行的规划。打算从北京出发,分别去若干个城市,然后再回到北京,每个城市之间均乘坐高铁,且每个城市只去一次。由于经费有限,希望能够通过合理的路线安排尽可能的省一些路上的花销。给定一组城市和每对城市之间的火车票的价钱,找到每个城市只访问一次并返回起点的最小车费花销。

输入描述:

城市 n(1<n≤10)

城市间的车票价钱 n行n列的矩阵 m[n][n]

输出描述:

最小车费花销 s

输入样例:

4

0 2 6 5

2 0 4 4

6 4 0 2

5 4 2 0

输出样例:

13

数据范围:1<n≤10

测试数据集:

// 输入

5

0 3 4 2 7

3 0 4 6 3

4 4 0 5 8

2 6 5 0 6

7 3 8 6 0

// 输出

19

// 输入

4

0 30 6 4

30 0 5 10

6 5 0 20

4 10 20 0

// 输出

25

// 输入

4

0 1 2 3

1 0 4 2

2 4 0 6

3 2 6 0

// 输出

11

// 输入

6

0 30 63 52 21 10

30 0 21 25 19 35

63 21 0 17 14 51

52 25 17 0 31 29

21 19 14 31 0 15

10 35 51 29 15 0

// 输出

111

// 输入

7

0 6 5 7 4 3 4

6 0 7 4 3 3 5

5 7 0 4 3 2 8

7 4 4 0 1 3 5

4 3 3 1 0 7 6

3 3 2 3 7 0 5

4 5 8 5 6 5 0

// 输出

22

【解题思路】

贪心算法,动态规划,最小生成树, 分治界限

分析:

1.因为最后走的路线为一个环,可以设城市0为起点城市。

2.将每个城市看作二进制的一个位(1代表有,0代表没有),则数k可以表示一些城市的集合(例如k=13,二进制表示为1101,表示城市0,2,3的集合),我们可以求得k<=2^15-1,令  aim=2^15-1;

3.dp[k][j]表示经过了k集合中的所有城市并且以j城市为终点的路径的最小值。

则dp[k][j] = Min{d

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

2024软件笔试真题+答案合集 文章被收录于专栏

本专刊由牛客官方团队打造,主要讲解名企校招技术岗位的笔试题,内容中包含多个名企的笔试真题,附有题目思路及参考代码

全部评论

相关推荐

本人末二本,C++后端选手,目前手里两个意向:美团移动端和字节客户端。但全网都是劝退客户端的,不知道要不要接。但现在转java已经没办法赶上秋招了,很焦虑,不知道要不要转java备战春招,求各位大佬给给建议。
小破站_程序员YT:作为一个末二本,c++后端选手,手握两个大厂意向,你竟然还在犹豫要不要接,还要去转java? 真不知道你怎么想的。不知道有多少人羡慕你还来不及。
点赞 评论 收藏
分享
投递广州诗悦网络科技有限公司等公司10个岗位 校招记录
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务