前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >阿里巴巴 2025 届校招开始了,岗位 and 原题抢先看!

阿里巴巴 2025 届校招开始了,岗位 and 原题抢先看!

作者头像
宫水三叶的刷题日记
发布2024-03-05 15:02:23
1590
发布2024-03-05 15:02:23
举报

阿里 春招 启动

阿里巴巴正式启动春季 2025 届校园招聘,其中超过 70% 均为技术岗位。

目前放出来的技术岗位中,工作地点分布在 杭州、北京、上海 和 成都 四个城市。

其中杭州占比最多,共有 25 种技术岗位可投递(总的技术岗位种类数为 28 类),杭州覆盖率高达 89%。另外三座城市的情况分别是:北京(9)、上海(8)和 成都(1)。

这里重点贴一下与公主号读者相关性较高的岗位。

算法:

算法工程师-计算机视觉

算法工程师-自然语言处理

算法工程师-机器学习

开发:

前端开发工程师

基础平台研发(C/C++/Java/Golang)

客户端开发工程师C++

测开:

测试开发工程师

目前招聘岗位刚放出来,有投递意向的同学可以开始着手准备了。

但也有注意事项 ⚠️⚠️⚠️:切忌海投!!!

...

回归主线。

无论是算法、研发还是测开,只要是计算机相关岗位,在校招中最不能绕过的环节是:算法

因此今天来带大家做一道「阿里巴巴」去年(2024 届毕业生)校招中的面试真题。

题目描述

平台:LeetCode

题号:791

给定两个字符串 orders

order 的所有单词都是唯一的,并且以前按照一些自定义的顺序排序。

s 的字符进行置换,使其与排序的 order 相匹配。

更具体地说,如果在 order 中的字符 x 出现字符 y 之前,那么在排列后的字符串中, x 也应该出现在 y 之前。

返回满足这个性质的 s 的任意排列 。

示例 1:

代码语言:javascript
复制
输入: order = "cba", s = "abcd"

输出: "cbad"

解释: 
“a”、“b”、“c”是按顺序出现的,所以“a”、“b”、“c”的顺序应该是“c”、“b”、“a”。
因为“d”不是按顺序出现的,所以它可以在返回的字符串中的任何位置。“dcba”、“cdba”、“cbda”也是有效的输出。

示例 2:

代码语言:javascript
复制
输入: order = "cbafg", s = "abcd"

输出: "cbad"

提示:

1 <= order.length <= 26
1 <= s.length <= 200
  • orders 由小写英文字母组成
  • order 中的所有字符都 不同

构造

根据题意进行模拟即可:起始先使用大小为

C = 26

的数组 cntss 的所有字符进行词频统计,随后根据 order 的优先级进行构造。

若字符 xorder 中排于 y 前面,则先往答案追加 cnts[x] 个字符 x,再往答案追加 cnts[y] 个字符 y,并更新对应词频,最后将仅出现在 s 中的字符追加到答案尾部。

Java 代码:

代码语言:javascript
复制
class Solution {
    public String customSortString(String order, String s) {
        int[] cnts = new int[26];
        for (char c : s.toCharArray()) cnts[c - 'a']++;
        StringBuilder sb = new StringBuilder();
        for (char c : order.toCharArray()) {
            while (cnts[c - 'a']-- > 0) sb.append(c);
        }
        for (int i = 0; i < 26; i++) {
            while (cnts[i]-- > 0) sb.append((char)(i + 'a'));
        }
        return sb.toString();
    }
}

C++ 代码:

代码语言:javascript
复制
class Solution {
public:
    string customSortString(string order, string s) {
        vector<int> cnts(26, 0);
        for (char c : s) cnts[c - 'a']++;
        string result = "";
        for (char c : order) {
            while (cnts[c - 'a']-- > 0) result += c;
        }
        for (int i = 0; i < 26; i++) {
            while (cnts[i]-- > 0) result += (char)(i + 'a');
        }
        return result;
    }
};

Python 代码:

代码语言:javascript
复制
class Solution:
    def customSortString(self, order: str, s: str) -> str:
        cnts = [0] * 26
        for c in s:
            cnts[ord(c) - ord('a')] += 1
        ans = ''
        for c in order:
            num = ord(c) - ord('a')
            if cnts[num] > 0:
                ans += c * cnts[num]
                cnts[num] = 0
        for i in range(26):
            if cnts[i] > 0:
                ans += chr(i + ord('a')) * cnts[i]
        return ans

TypeScript 代码:

代码语言:javascript
复制
function customSortString(order: string, s: string): string {
    const cnts = new Array<number>(26).fill(0)
    for (const c of s) cnts[c.charCodeAt(0) - 'a'.charCodeAt(0)]++
    let ans = ''
    for (const c of order) {
        while (cnts[c.charCodeAt(0) - 'a'.charCodeAt(0)]-- > 0) ans += c
    }
    for (let i = 0; i < 26; i++) {
        while (cnts[i]-- > 0) ans += String.fromCharCode(i + 'a'.charCodeAt(0));
    }
    return ans
}
  • 时间复杂度:
O(n + m)
  • 空间复杂度:
O(C)

,其中

C = 26

为字符集大小

我是宫水三叶,每天都会分享算法知识,并和大家聊聊近期的所见所闻。

欢迎关注,明天见。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2024-03-01,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 宫水三叶的刷题日记 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 阿里 春招 启动
    • 算法:
      • 开发:
        • 测开:
        • 题目描述
        • 构造
        相关产品与服务
        NLP 服务
        NLP 服务(Natural Language Process,NLP)深度整合了腾讯内部的 NLP 技术,提供多项智能文本处理和文本生成能力,包括词法分析、相似词召回、词相似度、句子相似度、文本润色、句子纠错、文本补全、句子生成等。满足各行业的文本智能需求。
        领券
        问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档