2023 联想笔试题 0809

笔试时间:2023年8月9日 秋招

第一题

题目:复制粘贴

输入一个长度为n的仅包含英文字母的字符串,下标从1开始。你对这个字符串进行如下操作Q次,第i次操作如下:

.li,ri,k,表示复制原串中下标为li,li+1,...,ri的字符串,之后:如果k=0,则将其粘贴在字符串的前面;如果k=1,则将其粘贴在字符串的末尾。你需要输出经过Q次操作后得到的字符串。

输入描述

第一行两个正整数n,Q(1<=n,Q<=2*10^4)

第二行一个长度为n的仅包含英文字母的字符串。

第三行包含Q个正整数l1,l2,...lQ;

第四行包含Q个正整数:r1,r2,...rQ;

第五行包含Q个正整数:k1,k2,...kQ;

数据保证;1<=li<=ri<=n,0<=ri-li<10,ki∈(0,1),且输入的区间范围合法。

输出描述

输出一行,表示最后得到的字符串。

样例输入

7 2

XabcdeZ

2 1

4 7

0 1

样例输出

abcXabcdeZXbcdeZ

第一次操作为l1=2,r1=4,k1=0,复制的子串为abc,将其粘贴在字符串开头,此时字符串为abcXabcdeZ.第二次操作为l2=1,r2=7,k2=1,复制的子串为XabcdeZ,即整个原串,将其粘贴在字符串末尾,此时字符串为abcXabcdeZXabcdeZ。

参考题解

模拟

C++:

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

int main() {
    int n, Q;
    cin >> n >> Q;
    cin.ignore();  // Ignore the newline character
    string s;
    getline(cin, s);
    int l[Q], r[Q], k[Q];
    
    for (int i = 0; i < Q; i++) {
        cin >> l[i];
    }
    
    for (int i = 0; i < Q; i++) {
        cin >> r[i];
    }
    
    for (int i = 0; i < Q; i++) {
        cin >> k[i];
    }
    
    string result = s;
    
    for (int i = 0; i < Q; i++) {
        if (k[i] == 0) {
            result = s.substr(l[i] - 1, r[i] - l[i] + 1) + result;
        } else {
            result = result + s.substr(l[i] - 1, r[i] - l[i] + 1);
        }
    }
    
    cout << result << endl;
    return 0;
}

Java:

import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);
        int n = sc.nextInt();
        int Q = sc.nextInt();
        sc.nextLine();
        String s = sc.nextLine();
        int[] l = new int[n];
        int[] r = new int[n];
        int[] k = new int[n];
        for (int i = 0; i < Q; i++) {
            l[i] = sc.nextInt();
        }
        for (int i = 0; i < Q; i++) {
            r[i] = sc.nextInt();
        }
    

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

2023 秋招笔试题汇总解析 文章被收录于专栏

2023秋招各大笔试题汇总,c++,java,python多种语言分析,解答。

全部评论

相关推荐

不愿透露姓名的神秘牛友
09-02 17:35
已编辑
鼠鼠秋招第一个面试居然就是联想的,感觉鸭梨山大😢最搞的是我岗位投错了,本来想投硬件工程师,结果不知咋的投成测开了,笔试里面的综测好好写完了,但是编程交的都是白卷😢本来以为挂了完事了,结果上午给我发面试通知,鼠鼠人都傻了,盯着通知看三遍也没看到“笔试通过”的字眼,难道笔试跟面试是不相关的吗?真的不想错过第一次面试机会,但又莫名有种要去自取其辱的违和感😢算了,它敢面我就敢去,🐴的跟它爆了,到时候完事了给大家补一下后续😋更新————9.2其实流程挺混乱的(第一次面试经验不足,请多谅解),我会尽力回忆一下,开头自我介绍,然后直接开始问代码,python循环,C循环,对服务器的了解(划重点,好多面经都有这个),CPU和GPU的区别,拷打项目,问几个项目相关的问题那个面试官简直坏得冒泡,开头聊几句发现鼠鼠没啥水平(其实就是投错岗位了,🐴的不是你们放我进的面试吗),然后就开始扯闲篇调戏我,还拿他擅长的东西跟我辩论,气得鼠鼠都想骂人了还得装作不生气的样子看他嘻嘻哈哈,然后就是经典的其他人学历比你好基础比你好你觉得自己的优势在哪里,我能说啥,我投错了我还能说啥😇,十分钟就能结束的事拖了半个小时反问:测开的工作内容和发展前景:简单说两句几轮面试:最少两轮评价一下面试表现:一般(我谢谢你奥)最后就是简历一定不要乱写!而且务必记住你给哪个企业投的简历是什么版本,搞错了就GG了!祝各位都能成功过面😌
秋招笔面试记录
点赞 评论 收藏
分享
评论
4
12
分享

创作者周榜

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