【春招笔试】携程 2024.03.28 春招笔试题解析

alt

01. 小柯的回文游戏

题目内容

小柯想玩一个有趣的回文游戏。给定一个正整数 ,她希望你能输出一个由 个 "you" 组成的字符串,其中第一个 "you" 正序输出,第二个倒序输出,第三个再正序,以此类推。你能帮帮她吗?

输入描述

输入只有一行,包含一个正整数 ,表示需要输出的 "you" 的个数。

输出描述

输出一个字符串,表示由 个 "you" 组成的字符串,奇数位置的 "you" 正序输出,偶数位置的 "you" 倒序输出。

样例1

输入:

5

输出:

youuoyyouuoyyou

题解

这是一个简单的字符串构造问题。核心思路是根据位置的奇偶性交替输出正序和倒序的 "you"。

首先定义两个字符串:正序的 "you" 和倒序的 "uoy"。然后根据位置的奇偶性决定输出哪一个。具体来说,当位置是偶数(从 0 开始计数)时输出 "you",当位置是奇数时输出 "uoy"。

这种方法的时间复杂度是 ,其中 是输入的整数。空间复杂度是 ,因为我们只需要常数级别的额外空间来存储两个固定的字符串。

对于给定的数据范围( 最大为 ),这个算法是高效的,因为最终生成的字符串长度不会超过 ,完全在可接受的范围内。

三语言参考代码

  • Cpp
#include <iostream>
#include <string>
using namespace std;

int main() {
    int cnt;
    cin >> cnt;
    
    string norm = "you";
    string revs = "uoy";
    string rslt = "";
    
    for (int idx = 0; idx < cnt; idx++) {
        if (idx % 2 == 0) {
            rslt += norm;
        } else {
            rslt += revs;
        }
    }
    
    cout << rslt << endl;
    return 0;
}
  • Python
def solve():
    cnt = int(input())
    
    norm = "you"
    revs = "uoy"
    rslt = ""
    
    for idx in range(cnt):
        if idx % 2 == 0:
            rslt += norm
        else:
            rslt += revs
    
    print(rslt)

if __name__ == "__main__":
    solve()
  • Java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int cnt = scan.nextInt();
        
        String norm = "you";
        String revs = "uoy";
        StringBuilder rslt = new StringBuilder();
        
        for (int idx = 0; idx < cnt; idx++) {
            if (idx % 2 == 0) {
                rslt.append(norm);
            } else {
                rslt.append(revs);
            }
        }
        
        System.out.println(rslt.toString());
    }
}

02. 小柯的花园修剪

题目内容

小柯有一个 的花园,每个位置上都种植了一株植物。然而,有些植物长得太茂盛了,需要修剪。小柯可以选择一个 的区域(即连续的两株植物),将它们修剪整齐。现在,小柯想知道,最少需要多少次修剪,才能让整个花园看起来整齐有序呢?

花园中的每一株植物可以用 0 或 1 来表示,0 表示植物长得刚刚好,不需要修剪,1 表示植物长得太茂盛,需要修剪。

输入描述

第一行包含两个正整数 ,表示花园的行数和列数,中间用空格隔开。

接下来 行,每行包含 个字符,表示花园中植物的状态,0 表示不需要修剪,1 表示需要修剪。

输出描述

输出一个整数,表示最少需要的修剪次数。

样例1

输入:

2 4
1010
1000

输出:

4

题解

这道题可以用贪心的思路来解决。关键观察是:每次修剪操作会影响两个相邻的植物,我们希望尽可能多地利用每次修剪来处理需要修剪的植物。

最优策略是:遍历花园中的每个位置,当遇到需要修剪的植物(值为 1)时,进行一次修剪操作,并将该植物和它右边的植物(如果存在)都标记为已修剪。这样可以保证每次修剪都是必要的,且尽可能利用了修剪操作的效果。

具体实现时,可以用一个二维数组来表示花园,然后遍历每个位置。如果当前位置的植物需要修剪且尚未被修剪过,就进行一次修剪操作,并更新相应的状态。

时间复杂度为 ,其中 分别是花园的行数和列数。空间复杂度也是 ,用于存储花园的状态。

对于给定的数据范围( 最大为 1000),这个算法是高效的,可以在合理的时间内得到结果。

三语言参考代码

  • Cpp
#include <iostream>
#include <vector>
using namespace std;

int main() {
    int rows, cols;
    cin >> rows >> cols;
    
    vector<string> yard(rows);
    for (int i = 0; i < rows; i++) {
        cin >> yard[i];
    }
    
    int cuts = 0;
    vector<vector<bool>> trim(rows, vector<bool>(cols, false));
    
    for (int r = 0; r < rows; r++) {
        for (int c = 0; c < cols; c++) {
            if (yard[r][c] == '1' && !trim[r][c]) {
                cuts++;
                trim[r][c] = true;
                
                // 修剪右边的植物(如果存在)
                if (c + 1 < cols) {
                    trim[r][c+1] = true;
                }
            }
        }
    }
    
    cout << cuts << endl;
    return 0;
}
  • Python
def solve():
    rows, cols = map(int, input().split())
    yard = [input() for _ in range(rows)]
    
    cuts = 0
    trim = [[False for _ in range(cols)] for _ in range(rows)]
    
    for r in range(rows):
        for c in range(cols):
            if yard[r][c] == '1' and not trim[r][c]:
                cuts += 1
                trim[r][c] = True
                
                # 修剪右边的植物(如果存在)
                if c + 1 < cols:
                    trim[r][c+1] = True
    
    print(cuts)

if __name__ == "__main__":
    solve()
  • Java
import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scan = new Scanner(System.in);
        int rows = scan.nextInt();
        int cols = scan.nextInt();
        
        char[][] yard = new char[rows][cols];
        for (int r = 0; r < rows; r++) {
            yard[r] = scan.next().toCharArray();
        }
        
        int cuts = 0;
        boolean[][] trim = new boolean[rows][cols];
        
        for (int r = 0; r < rows; r++) {
            for (int c = 0; c < cols; c++) {
                if (yard[r][c] == '1' && !trim[r][c]) {
                    cuts++;
                    trim[r][c] = true;
                    
                    // 修剪右边的植物(如果存在)
                    if (c + 1 < cols) {
                        trim[r][c+1] = true;
                    }
                }
            }
        }
        
        System.out.println(cuts);
    }
}

03. 小柯的农场优化问题

题目内容

小柯拥有一个农场,农场中种植了一排果树,共有 棵。每棵果树都有一个对应的收益值 ,可正可负。

现在,小柯最多可以进行一次优化操作:选择一个由偶数棵果树组成的连续区间,将这个区间内所有果树的收益都减半。

请你帮助小柯进行最佳决策,使得优化后整个果园的总收益最大。

输入描述

第一行包含一个正整数 ,表示果树的数量。

第二行包含 个整数 ,分别表示每棵果树的收益值。

输出描述

输出一个整数,表示优化后果园的最大总收益。

样例1

输入:

5
8 -4 2 -6 -5

输出:

-1

题解

这道题目要求通过最多一次优化操作(将连续偶数个果树的收益减半)来最大化总收益。关键是找到一个合适的连续区间,使得减半后的总收益最大。

首先,我们需要计算原始的总收益。然后,考虑所有可能的由偶数棵果树组成的连续区间,计算将该区间内的收益减半后的新总收益,并找出最大值。

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

互联网刷题笔试宝典 文章被收录于专栏

互联网刷题笔试宝典,这里涵盖了市面上大部分的笔试题合集,希望助大家春秋招一臂之力

全部评论

相关推荐

06-18 21:31
已编辑
南京航空航天大学 Java
总结:一共半小时,比想象中要长,问了比较多场景题,&nbsp;面试风格和技术面完全不同。提问环节1.你能否先做一个自我介绍,开始今天的面试?2.你的求职意向中,是否考虑除了网络安全方向外,还会考虑java后端、测试开发等其他岗位?3.问:你是否已经确定要去做测试开发方向的工作,还是同步考虑后端岗位?答:我认为都可以考虑,现在还没有限制得很死,还在探索阶段。4.问:你在找实习时,除了测开岗位外,是否也投递了一些后端岗位?答:其实都有在投递,不会限制得很死,前端后端都会考虑。5.问:你目前是否拿到较为满意的offer,为什么可能会优先考虑我们公司?答:确还有一些offer在流程中,我对贵公司的价值观比较认同,所以可能会优先考虑。6.问:能否分享一个你在硕士期间做的相对满意、有成就感或具有挑战性的项目,包括项目背景、目的、你在其中的工作内容以及满意之处?7.问:在项目推进过程中,有哪些比较满意的点,如果重新来过,有哪些层面可以做得更好?8.问:你是否有实习经历,在之前的实习岗位是做什么的?9.问:你在实习期间实习了多久?10.问:在企业实习(如实习神经学、大数据和网络安全等岗位)与学校跟随导师做实验室项目,两者之间有什么核心差异?答:核心差异在于研究生阶段的研究工作更多是探索性的工作,在前人基础上挖掘新的领域;而在企业实习则是针对已有的岗位和明确的工作职责,主要任务是掌握当前的工作岗位,不需要过多的探索性工作。11.问:在之前实习的过程中,遇到的最大挑战是什么?答:最大的挑战是适应体制内工作,学会半文半事,与不同人打交道,包括参加会议并做会议纪要等文书工作。12.问:在实习期间,你在做人和做事能力上有哪些具体的提升?13.问:你是否有设想过如果来到互联网公司实习后可能会遇到哪些困难,并且是否决心从事互联网行业?答:认为人生是探索,虽然了解到互联网行业的差异,但尚未深入了解,打算通过实习期间的探索,尝试进入互联网行业作为未来可能的第一份工作。14.问:如果我给你这样一个暑期实习offer,你过来之后,在上手和工作推进过程中,你觉得会遇到哪些层面的挑战或困难?答:我觉得我的岗位是测试开发,主要挑战包括编写和执行测试文档,以及进行自动化测试和基础平台的研发。这些工作都是我之前没有接触过的,需要在短期内熟悉公司的流程和技术要求,例如学习自动化测试所需的Python语言或基础平台开发能力,以及熟悉测试文档的结构、编写到执行的全流程和缺陷生命周期管理。15.问:做好这个暑期实习岗位的核心能力层面有哪些?答:核心能力层面首先是编码能力,因为进行技术平台开发时编码是必需的。其次,沟通能力也很重要,需要与产品经理、开发人员进行有效沟通。所以提升编码能力和沟通能力都是必要的。16.问:你觉得我们公司或实习岗位对你来说比较好的地方主要在哪些层面?答:我觉得主要优势在于公司的定位,作为阿里系公司,拥有足够大的平台,这对于个人能力是一种很好的背书。此外,工作地点在杭州或上海,这两个地方我都喜欢,并且对测试开发相关工作内容较为熟悉,有助于能力增长。17.问:你能否客观分析一下,觉得自己与其他申请者相比,在哪些方面具有优势和劣势?18.问:你是否可以接受上海和杭州这两个地点作为实习地点?19.问:实习时间上,你最快什么时候能开始,最晚可以实习到什么时候?反问环节1.问:公司主业是否偏向某一地?答:公司没有所谓的主业或总部概念,外卖业务上上海和杭州是双核心定位,而从阿里整体来看,杭州是总部所在地。2.问:上海这边的团队主要负责哪一块业务?答:上海团队主要负责首页APP交易到购物车、下单页的链路测试,同时负责创新型业务如拼团、秒杀、卡券类业务闭环开发,以及营销工具玩法(超级吃货卡、红包、吃货豆等)的设计与测试。3.问:是否可以了解一下工作节奏?答:实习期间,公司对实习生的工作量期望并不高,更关注实习生主动学习能力和对业务的理解深度。正常情况下,正式员工晚上一般在8点至9点半之间下班,但若项目上线节奏紧张时,可能会有所加班。
查看19道真题和解析
点赞 评论 收藏
分享
评论
2
4
分享

创作者周榜

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