阿里算法offer真不是那么好拿的

本人bg:阿里妈妈,算法工程师,针对长序列做精准的出价决策的

阿里校招offer真的不是那么好拿的,没点真本事现在真的不好进来了,而且阿里校招分散到了各个层面,有的是直接校招,有的是实习转正,还有很大的头是竞赛,有数学竞赛、有编程竞赛、有大模型竞赛,而且一个比一个重磅。

最近阿里妈妈又开放的这个NeurPS是有极高的国际影响力的,这次比赛也将首次公开约5亿条博弈数据及相应的训练框架,如此大规模的博弈数据在业界是非常少见的,如果你是研究决策智能、强化学习、博弈和生成式模型等领域,那绝对是一次非常好的机会。

此外阿里妈妈这次还提供了超多重磅福利:

  • 前10名的队伍将获得由阿里妈妈颁发的比赛证书。
  • 前10名队伍的成员将有机会参观阿里巴巴和北京大学,深入了解阿里妈妈的广告平台,并与行业优秀工程师和学术研究人员进行面对面的交流。
  • 阿里妈妈将优先为学生提供长期实习机会,为研究人员提供长期访问学者机会。
  • 前50名队伍的成员将有机会通过绿色通道直接内推简历(真内推)
  • 取得优异成绩的成员将有机会赢得6000美元的赛事奖金!

报名链接:https://link.zhiyeapp.com/r/1kWXgz2BmJ

一共2个赛道:

赛道1:AIGB赛道: 利用生成式模型学习自动出价Agent

在这个赛道中,参赛者需要解决如何针对长序列做精准的出价决策。由于众多竞争对手的策略不断变化,竞价环境异常激烈。传统方法,例如基于强化学习的策略,在面对较长序列决策时,受到误差累积等因素的限制,其性能表现受限。近年来,广义生成模型在决策任务上展现出了较好的应用潜力。因此,本赛道要求参赛者采用广泛的生成式模型,如Diffusion Models、Transformers等,来应对这一挑战。我们诚邀拥有Diffusion Models、Transformers、Foundation Models、大型语言模型(LLMs)及其他生成方法背景的研究者和从业者参与这一挑战。

赛道2:通用赛道:含不确定性的自动出价

在这个赛道中,参赛选手面临的挑战是在大规模拍卖中做出有效的出价决策,这需要有效地感知竞争对手策略的变化。真实世界中复杂的广告拍卖环境带来了额外的挑战,即不确定性。参与者必须考虑消费者到达的随机性、转化行为预测的方差、数据稀疏性及其他因素。我们鼓励参赛者采用多样和创新的方法来解决这一问题。我们欢迎具有强化学习、优化、机器学习、博弈论和数据科学背景的研究人员和从业者来参加这一挑战。

感兴趣可以直接去报名啦,报名时间仅仅有1周,报名链接:https://link.zhiyeapp.com/r/1kWXgz2BmJ

#阿里妈妈NeurIPS 2024#
全部评论
刚注册低级号闹麻了
9 回复 分享
发布于 2024-07-31 23:00 伊朗
普通学生哪里玩的起LLM啊,这竞赛有啥用
3 回复 分享
发布于 2024-07-31 18:33 江苏
这才是研究大模型的公司
2 回复 分享
发布于 2024-07-31 15:58 浙江
中厂算法比如我们公司要容易一些,给的也很高
1 回复 分享
发布于 2024-08-05 16:54 黑龙江
我可以报名赛道3
1 回复 分享
发布于 2024-07-31 15:56 宁夏
确实不好拿
1 回复 分享
发布于 2024-07-31 15:53 山东
我们这也招哦
点赞 回复 分享
发布于 2024-08-01 17:10 上海
5亿条博弈数据和训练框架!!
点赞 回复 分享
发布于 2024-07-31 16:00 北京
我不配啊
点赞 回复 分享
发布于 2024-07-31 15:52 山东

相关推荐

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

创作者周榜

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