🔥 58同城「58A计划」精英招募正式启动!

🔥 58同城「58A计划」精英招募正式启动!寻找未来的技术领军者!

你是2025年10月及之后毕业的顶尖技术人才吗?
学术拔尖?竞赛王者?实践先锋?
58同城「58A计划」为你敞开核心战场的大门!

为什么选择58A计划?

🏆 行业Top薪酬: 实力匹配价值,给予你最具竞争力的回报起点。
👨‍🏫 顶尖导师天团: 与技术大咖并肩,获得业界一流专家的深度指导与成长加速。
💻 核心业务淬炼: 直面亿级用户平台的技术挑战,在最关键的业务战场上施展才华、创造价值。
🚀 高起点发展平台: 加入民生服务科技巨头,多元业务生态提供广阔空间与超强抗风险能力。
我们寻找这样的你:

2025年10月及之后毕业的本科、硕士、博士。
在学术研究、技术竞赛、项目实践任一领域有突出亮眼成果者优先!
✨ 即刻行动,加入顶尖技术阵营!✨

🔺 投递通道:

💻 PC端直达: 立即访问 58同城校园招聘官网,搜索“58A计划”岗位!
📱 移动端便捷投: 微信关注 【58同城招聘官微】 公众号 → 点击菜单栏 【校园招聘】 → 锁定 「58A计划」 心仪岗位,一键投递!
🏠 58同城|让每一份热爱皆得归属!

我们深耕招聘、房产、汽车、本地生活服务等民生领域,旗下拥有赶集直招、58魔方、中华英才网、安居客、58爱房、巧房、58到家、人人车、驾校一点通、转转、58数科等领先品牌,构建稳健生态,创造巨大社会价值。
#58同城##算法工程师##校招#
全部评论

相关推荐

中途加入只写了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个岗位
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

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