字节跳动历年秋招笔试真题
如需获取完整资料,请点击下方链接领取《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%内容,订阅专栏后可继续查看/也可单篇购买
本专刊由牛客官方团队打造,主要讲解名企校招技术岗位的笔试题,内容中包含多个名企的笔试真题,附有题目思路及参考代码