百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

腾讯2020校园招聘(后台)算法编程题合集

haoteby 2025-02-26 12:14 11 浏览

腾讯2020校园招聘算法题,“压缩字符串”和“逛街”

总体来说,腾讯2020年的校园招聘职位相对较多,5道题目中主要考察了学生的算法基础与正则表达式的运用。

我这边抽出了前2道题跟大家分享,第一道题和昨晚字节跳动的题目类似,都可以使用正则表达式来做。第二道题用分治的方式也非常简单

[编程题一]压缩算法

输入描述:

输入第一行包含一个字符串s,代表压缩后的字符串。
S的长度<=1000;
S仅包含大写字母、[、]、|;
解压后的字符串长度不超过100000;
压缩递归层数不超过10层;

输出描述:

输出一个字符串,代表解压后的字符串。

输入例子1:

HG[3|B[2|CA]]F

输出例子1:

HGBCACABCACABCACAF

例子说明1:

HG[3|B[2|CA]]F?>HG[3|BCACA]F?>HGBCACABCACABCACAF

详细解答

//JAVA版本
import java.io.*;
import java.util.*;
public class Main{
    public static void main(String[] args){
        Scanner sc = new Scanner(System.in);
        Main main = new Main();
        String line = sc.nextLine();
        StringBuilder sb = new StringBuilder(line);
        main.decode(sb);
        System.out.println(sb.toString());
    }
     
    private void decode(StringBuilder string){
        int i=0;
        int start=-1, mid=-1, end=-1;
        while(i
#include 
 
using namespace std;
 
int main(){
    string s;
    cin >> s;
    int i = 0;
    while(i < s.length()){
        if(s[i] == ']'){
            int j =i; 
            int k = 0;
            while(s[j] != '['){
                if(s[j] == '|')
                    k = j;
                j--;
            }
            int len = stoi(s.substr(j+1, k-j-1));
            string s1 = s.substr(k+1, i-k-1);
            string s2;
            for(int si =0; si 


【编程题二】逛街

输入描述:

输入第一行将包含一个数字n,代表楼的栋数,
接下来的一行将包含n个数字wi(1<=i<=n),代表每一栋楼的高度。
1<=n<=100000;
<=wi<=100000;?

输出描述:

输出一行,包含空格分割的n个数字vi,分别代表小Q在第i栋楼时能看到的楼的数量。

输入例子1:

6
5 3 8 3 2 5

输出例子1:

3 3 5 4 4 4

例子说明1:

当小Q处于位置3时,他可以向前看到位置2,1处的楼,
向后看到位置4,6处的楼,加上第3栋楼,那小Q一共能够看到5栋楼(2,1,3,4,6)。
当小Q处于位置4时,他可以向前看到位置3处的楼,向后看到位置5,6处的楼,
加上第4栋楼,共可看到4栋楼(3,4,5,6)。

详细源码:

//JAVA 使用栈实现,非常简单
//用栈两个方向分别遍历一次,最后相加,时间复杂度为O(n);
import java.util.Stack;
import java.util.Scanner;
public class Main{
    public void street(int num, int[] build){
        int[] res = new int[num];
        Stack sl = new Stack<>();
        //从前向后遍历,相当于每个楼往右边能看到几个
        for(int i=0; i sr = new Stack<>();
        //从后向前遍历,相当于每个楼往左边能看到几个
        for(int i=num-1; i>=0; i--){
            res[i] += sr.size();
            //维护栈,为一个楼做准备
            while(!sr.isEmpty() && sr.peek()<=build[i]) sr.pop();
            sr.push(build[i]); //当前楼一定能被下一个楼看见
        }
        for(int a : res) System.out.printf("%d ",a);
    }
    public static void main(String[] args){
        Main m = new Main();
        Scanner sc = new Scanner(System.in);
        int num = sc.nextInt();
        int[] build = new int[num];
        int i = 0;
        while(sc.hasNextInt()) build[i++] = sc.nextInt();
        m.street(num,build);
    }
}

//Python详细注释版本,代码中保留了调试过程中的一些输出,大家代码如果读起来有困难可以跟着调试
// # -*- coding:utf-8 -*-
// 单调栈进攻!!
import sys
n = int(sys.stdin.readline().strip())
l = list(map(int, sys.stdin.readline().strip().split()))
def handle(house):
    // 设置栈,储存往回看能看到的楼的高度
    //设置结果,储存每栋楼往回看能看到几个
    stack , res = [house[0]] , [0]*n
    // 然后对这个栈
   // 进行循环,每检查一栋楼都是酸这栋楼往回看能看到几栋
    for i in range(1,n):
        res[i] = len(stack)
        //print(i,'th now res is ',res)
        //只要这栋楼比stack里面的最后一个比,如果最后一个大或者等于就把stack[-1]删掉,一直比
       // 直到没问题。
        if stack[-1] <= house[i]:
            while stack and stack[-1] <= house[i]:
                //print('stack last one is ',stack[-1],' smaller than ',i,'th house')
                //print("now stack pop this one ",stack[-1])
                stack.pop(-1)
                // print('stack is now ',stack)
            stack.append(house[i])
            //print('stack append new house ',house[i],' and stack is now ',stack)
            continue
        // 小于等于的话就直接加进去,保证单调性
        //print('stack last one bigger than ',i,' th house so append')
        stack.append(house[i])
        //print('stack is now ',stack)
    // print('res is ',res)
    return res
resA = handle(l)
resB = handle(l[::-1])[::-1]
print(  " ".join(list(map(str, [resA[i] + resB[i] + 1 for i in range(n)]))))

总结

腾讯的校招算法题还是相对较简单,只要认真学习了数据结构与算法的朋友应该都能轻松过关。无非是解决问题的方式优劣性。比如使用递归的时候要尽量使其不重复计算。能用递归的就尝试用动态规划试试。

至于有朋友说时间复杂度和空间复杂度的问题,我这边直接给大家科普一下这两者,方便大家以后自己计算。

下面是一段计算从1到n的3次方和。

假设:我们将计算执行一次的时间分割为一个时间单元,所有的申明不计算时间单元。

结论:图片中第一行和第四行各占1个时间单元,第三行每执行一次占用4个时间单元(两次乘法,一一次加法,一次赋值),那么执行N次所用的时间单元是4N。

第二行在初始化i算一个时间单元,判断i<=N使用N+1个时间单元和i自增N次运算隐含N时间单元,那么总共就是2N+2.

最后我们如果忽略方法的调用和返回值,那么总共消耗时间单元是6N+4;所以我们说这个方法的时间复杂度为O(N)。

其实上面的说明主要为了大家理解时间复杂度如何来的,在平时我们根本不用这样去详细计算。我们总是会去估计一个每一个模块的最大时间复杂度,然后计算。

比如For循环的时间复杂度最多是迭代次数乘以For内部的复杂度。一般是O(N),嵌套For一般是O(N平方)

好了,希望我的这个说明能帮助大家理解时间复杂度怎么来的,如果有不懂的欢迎探讨。

相关推荐

Python爬虫进阶教程(二):线程、协程

简介线程线程也叫轻量级进程,它是一个基本的CPU执行单元,也是程序执行过程中的最小单元,由线程ID、程序计数器、寄存器集合和堆栈共同组成。线程的引入减小了程序并发执行时的开销,提高了操作系统的并发性能...

A320-V2500发动机系统FADEC介绍(2)

目的全权数字发动机控制(FADEC)系统在所有飞行和运行阶段提供全范围发动机控制。...

三国志战棋版:玩家“二叔”用这套群DOT在比武中拿下31胜5负

声明:本文首发于今日头条,而后发布于“鼎叔闯三棋”的微信公众号、抖音、哔哩哔哩和小红书平台,如果在其他平台就是抄袭。...

真正的独一无二:Dot One 推出 DNA 定制系列 139英镑起

相信很多人在挑选衣物时有着这样的困扰,综合了性价比、面料等因素后好不容易找到了心仪的款式,还要担心是否会撞衫,不管是擦肩而过的陌生人还是身边的熟人,都令人尴尬。小部分人为此热衷于购买少量的古着或者限量...

崩铁:周年庆福利再升级,老角色加强时间确定,3.xdot体系反转

#埃安UT大一圈高级很多#...

Dotgo推出RBMHub,扩大了CPaaS提供商的覆盖范围和功能

据telecompaper网7月15日报道,用于商业消息传递的RichCommunicationServices(RCS)解决方案的领先提供商Dotgo宣布推出RBMHub。RBMHub的推出扩大了C...

深度解析:快照取消Dot职业的将何去何从

写在前面曾几何时,术士的出现便被冠以dot大师的名头,从远古时期的献祭腐蚀虹吸不如暗牧一个痛,到TBC上满dot=荣誉击杀+1,到wlk接近全暴击的冰晶腐蚀,再到CTM就算了吧MOP的各种变态吸x放...

星穹铁道:抽卡芙卡之前,你必须了解什么是dot!

卡妈终于上线了,可还是有很多人不明白什么是dot伤害,抽了卡妈直接玩起了直伤流,把一个持续伤害的引爆器玩成了打手,卡妈打dot伤害是远高于直伤的,有了卡妈的玩家一直了解dot,不然这卡妈就真被玩成四不...

游戏界的闪耀星辰陨落:悼念知名游戏博主″dotα牛娃″

无尽哀思!在数字时代浪潮中,游戏不仅是消遣娱乐的代名词,更是连接心灵的桥梁,构筑了无数人的青春回忆。在这片浩瀚无垠的游戏宇宙中,有这样一位博主,他以独特的风采、深邃的洞察力和无尽的热情,成为了玩家心中...

直击2017新加坡同性恋聚会Pink Dot,自由爱!

今年的“粉红点”又来啦~这个支持LGBT群体(男女同志、双性恋、跨性别等)群体的活动,从2009年起,已经在新加坡举办8年了!”这个非营利的同性恋权益活动,主要是希望大家了解到,不管一个人的性倾向或...

python-dotenv,一款超级实用处理环境变量python库

python-dotenv,一款超级实用处理环境变量python库python-dotenv概述:...

亚马逊语音助手毫无征兆发笑 诡异至极吓坏用户

来源:新华网美国电商亚马逊7日承诺,将更改名下“亚历克萨”语音系统设置,令它不会莫名发笑,免得吓坏用户。“亚历克萨”是亚马逊开发的语音助手软件,可服从用户语音指令完成对话、播放音乐等任务。依照原来设计...

2022最火英文网名男女生

精选好听英文昵称带翻译1.moveon(离开)2.Monster(怪物)3.Solo吉他手4.Finish.(散场)...

智能家具 RecycleDot 的出现给传统家具厂商带来新的挑战

从可穿戴手环、手表到智能衣服,智能硬件逐步渗透到每一个领域。最近有一对父子MikeSandru和JohnSandru在自家的车库中设计了一款智能家具RecycleDot,给日渐萧条的家具行...

欧洲通信卫星公司 OneWeb 敦促印度DoT尽早批准提供卫星宽带服务

据telecomtalk2月17日报道,欧洲通信卫星公司EutelsatOneWeb近日敦促印度电信部(DoT)尽快批准其在印度部署双地球站网关的计划,以便连接其近地轨道(LEO)全球卫星星座,并...