小红书笔试

uu们做小红书的笔试了吗?题真的好难,一道题没做上来,还有一道题只ac了 9%
全部评论
诶我去,我测试用例过了就没管了,保存并提交必须要按吗
4 回复 分享
发布于 08-13 21:42 广东
1+0.09+0.09
4 回复 分享
发布于 08-13 20:58 北京
感谢分享 我主页简介有最近在做的大厂项目,可以包装简历,秋招机会更多,不然的话没有一个好的实习或者项目秋招很难通过筛选,竞争激烈
点赞 回复 分享
发布于 昨天 14:47 江苏
我最后一题跑用例基本没问题一实际运行就超时然后9%,太破防了
2 回复 分享
发布于 08-13 21:00 广东
第一题有什么特别注意事项吗,自测没问题就9%
点赞 回复 分享
发布于 昨天 11:37 上海
xhs要找超人?
2 回复 分享
发布于 08-13 20:55 上海
80%+9%,真是难到爆炸了
点赞 回复 分享
发布于 昨天 09:49 北京
第一题:分配数位数字,贪心最大放最大 第二题:简单dp过程,输出答案的时候需要扫描一下 第三题:计数=组合数+求逆元(题目备注了费马小定理,直接快速幂即可)
1 回复 分享
发布于 08-13 21:23 重庆
最后一题吧我也a了9%,说我超时了,真的服了
点赞 回复 分享
发布于 昨天 09:48 北京
我就最后一道有个9%
1 回复 分享
发布于 08-13 20:56 海南
第一题一开始9% 后面改成long就ac了 第二题9% 第三题放弃
点赞 回复 分享
发布于 昨天 05:48 江苏
第一题9%,我😅
1 回复 分享
发布于 08-13 20:56 江苏
第二题看了好久才看懂题说的啥,但是也没时间了,脑子已经浆糊了
点赞 回复 分享
发布于 昨天 02:09 上海
招超人吧,题这么难
点赞 回复 分享
发布于 08-13 23:14 黑龙江
三题只写对了第一题,能进面试吗?
点赞 回复 分享
发布于 08-13 22:32 浙江
第一题没看懂
点赞 回复 分享
发布于 08-13 21:06 广东
第一题做了第三题9%第二题最后做的,还没写出来
点赞 回复 分享
发布于 08-13 21:05 湖北
已老实
点赞 回复 分享
发布于 08-13 21:05 北京
为啥第一题过不了,不就是排序后先放高位
点赞 回复 分享
发布于 08-13 21:02 上海
第一题9%
点赞 回复 分享
发布于 08-13 21:00 浙江

相关推荐

中途加入只写了1,3,第二题没看懂要干啥第一题:优先队列 + 贪心可以想到贪心,先把所有的数给拆出来,比如[11, 299],拆成[9,9,2,1,1],然后贪心,把大的数放在位数高的那个元素就行了,比如例子中可以变成[(1,2), (2,3)]表示第一个数有两位,第二个数有三位,然后放入优先队列,首先取出第二个元素,将第三位变成9,现在第二个元素只剩两位了,继续放入优先队列,按照该顺序写就OK。代码如下:#include <bits/stdc++.h>using namespace std;const int N = 2e5 + 10;int a[N] ,h[10];pair<int, int> b[N];int main() {int n;cin >> n;priority_queue<pair<int, int>> pq;for (int i = 0; i < n; i ++) {cin >> a[i];b[i].second = i;while (a[i]) {h[a[i] % 10] ++;a[i] /= 10;b[i].first ++;}pq.push(b[i]);}while(pq.size() > 0) {pair<int, int> t = pq.top();pq.pop();int num = 0;for (int i = 9; i >= 0; i --) {if (h[i] != 0) {h[i] --;num = i;break;}}a[t.second] = a[t.second] * 10 + num;t.first--;if (t.first !=0) {pq.push(t);}}long long res = 0;for (int i = 0; i < n; i ++) res += a[i];cout << res;}第三题:组合数首先要推公式,如果两个数a[i]和a[j]之间有n个0,设z = a[j] - a[i], 有多少种可能的序列,设为f(z, n),C是组合数。当n = 1 时,记为f(z, 1),很简单,该0可能是a[i] - a[j]之间的任何数,有z + 1 种可能,f(z, 1) = z + 1 = C(z+1, 1)。当n = 2 时,固定第一个0,如果第一个0为x,那么第二个0就和n = 1 时一样,此时枚举第一个0从[0-z],f(z, 2) = f(z,1) +f(z-1,1) + ...+f(1, 1) + f(0, 1) = 1 +... +z+1 = C(z+2, 2)。同理, n=3时,同理枚举第一个0。f(z, 3) = f(z, 2) +... f(0, 2) = C(z+2, 2) + C (z + 1, 2) + ... C(2, 2) = C(z+3, 3)可以看出来f(z, n) = C(z + n, n) = (z +n)!/(n! & z!);#include <bits/stdc++.h>using namespace std;#define int long longconst int p = 1e9 + 7;const int N = 6e5 + 10;int a[N];int mul[N], dmul[N];int qs(int a, int b) {int res = 1;while (b) {if (b&1) res = res * a % p;a = a * a % p;b >>= 1;}return res;}int C(int n, int m) {int cc = 1;for (int i = n - m + 1; i <= n; i ++) cc = cc * i %p;return cc * dmul[m] % p;}int lucas(int n, int m) {if (m == 0) return 0;int a = n % p, b = m % p;if (b > a) return 0;return C(a, b) * lucas(n/p, m /p) % p;}signed main() {int n; cin >> n;vector<int> v;int res = 1;mul[0] = dmul[0] = 1;for (int i = 1 ; i < N ; i ++) {mul[i] = mul[i - 1] * i % p;dmul[i] = qs(mul[i], p - 2);}for (int i = 1 ;i <= n; i ++) cin >> a[i];for (int i = 1 ; i < n; ) {if (a[i] == 0) {int j = i;while (a[j] == 0) j++;int d = a[j] - a[i - 1];int z = j - i;res = res * C(z + d, z) % p;i = j;} else i++;}cout << res << '\n';}
投递小红书等公司10个岗位
点赞 评论 收藏
分享
评论
5
收藏
分享

创作者周榜

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