美团算法笔试

选择题8题,一题2.25分,一共20分
编程题4题,一题20分,一共80分

第一题求l到r内有多少个数字有奇数个因数,很明显是完全平方数的个数,所以答案是sqrt(r)-sqrt(l-1)

第二题是写朴素贝叶斯二分类器,题面把整个过程都描述出来了,对着模拟

第三题是给了一棵树,根是1,每个节点给了一个权值a[i],然后每个节点x可以向x->1路径上第一个a[y]严格大于a[x]的节点y连一条边,最后要求每个节点到根节点1的最短路径长度,这个很明显在dfs的过程中维护单调栈找到连边,连完之后从1开始bfs即可

第四题是给了一张无向图,每个点的点权是点编号+实时的度,q次询问,每次要么删一条边,要么问节点x所在的连通块里面最大的权值,这个离线询问用并查集来做,把所有query按顺序存下来,首先将所有要删的边删掉,把其他边连起来维护并查集以及集合内最大权值,然后倒着枚举query,遇到opt=1也就是删边的query就进行连边,维护并查集,遇到opt=2也就是查询就直接查询此时x节点所在的连通块最大权值,把答案记下来,最后按照询问的顺序把这些答案输出即可

#美团笔试##美团##笔试#
全部评论

相关推荐

03-14 17:03
C++
第一题:给一个区间[l, r],计算区间中整数的因子数是奇数的个数并输出,比如12的因子数有:1,2,3,4,6,12,因此12不符合条件。这题只要意识到因子数都是成对出现的即可,只有当有2个因子数相等时才会出现奇数情况,比如:1=1*1, 4=2*2, 9=3*3,81=9*9我是对左右区间开平方取整,然后相减即可,注意想清楚并处理闭区间的特殊情况第二题:给定一个超级斐波拉契数列,前k个值为1,第n项是前n-1到n-k之和,输入k和q,q代表查询次数,接下来有q次输入,每次输入x,x代表查询第x项,输出答案,答案可能很大,因此要求输出对(10^9+7)取模这题考的时候想复杂了,半天没写出来,后来理清楚思路之后感觉也还好,但感觉还是挺多坑的,滑动窗口应该是最优时间复杂度吧。#include <bits/stdc++.h>using namespace std;const int MOD = 1e9 + 7;// 参数:滑动数组、窗口大小、淘汰指针、结果、目标项序号、当前序号int search(vector<long long>& path, int& k, int& re, long long& result, int& x, int& index){// [re]需要用之前的result更新,而result又需要用[re]更新,因此必须用一个临时变量操作int reval = path[re];         //临时变量保留滑出的值,用于更新resultpath[re] = result;            //更新滑动窗口++re;                         //更新滑动指针,并检测环if(re==k)re = 0;++index;                              //更新indexresult = (result*2 - reval) % MOD;    //更新第index项的值if (result < 0) result += MOD;        // 保证非负if(index==x)return result;return search(path, k, re, result, x, index);}int main(){int k;int q;cin >> k >> q;while(q--){int x;cin >> x;vector<long long> path(k, 1);int re = 0;long long result = k;index = k+1;if(x<=k)cout << 1;else if(x==k+1)cout << k;elsecout << search(path, k, re, result, x, index); //从第k+1项开始才滑动if(q!=0)cout << endl;}return 0;}
点赞 评论 收藏
分享
评论
5
5
分享

创作者周榜

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