小米嵌入式软件实习笔试编程题

《嵌入式软件开发笔试与面试手册》https://blog.nowcoder.net/zhuanlan/jvN8gj

《嵌入式软件笔试-2023年真题汇总》https://blog.nowcoder.net/zhuanlan/0oDWVm

偏爱的字符

题目描述:

小李天生偏爱一些字符,对于一个字符串,他总是想把字符串中的字符变成他偏爱的那些字符。如果字符串中某个字符不是他所偏爱的字符,称为非偏爱字符,那么他会将该非偏爱字符替换为字符串中距离该字符最近的一个偏爱的字符。这里的距离定义即为字符在字符串中的对应下标之差的绝对值。如果有不止一个偏爱的字符距离非偏爱字符最近,那么小李会选择最左边的那个偏爱字符来替换该非偏爱字符,这样就保证了替换后的字符串是唯一的。小李的所有替换操作是同时进行的。

假定小李有m个偏爱的字符,依次为c1,c2...cm,当小李看到一个长度为n的字符串s时,请你输出小李在进行全部替换操作后形成的字符串。

输入描述

第一行输入两个正整数nm

接下来一行输入m个字符c1,c2...cm,每两个字符之间用空格隔开,表示小李偏爱的字符。

接下来一行输入一个字符串s

1n1000001m26,保证题目中所有的字符均为大写字符,小李偏爱的字符互不相同,且偏爱字符至少出现一次。

输出描述

输出一行字符串,表示小李将给定的字符串s替换后形成的字符串。

样例输入

12 4

Z G B A

ZQWEGRTBYAAI

样例输出

ZZZGGGBBBAAA

提示

字符Q为非偏爱字符,且偏爱字符Z距离它最近,所以替换成Z;同理E距离G最近,替换成G

对于字符W,偏爱字符ZG与其距离相同,所以替换为左边的Z

.......

对于字符 I ,右边没有偏爱字符,左边第一个偏爱字符是A,所以替换成字符A

同一个偏爱字符可能会在字符串中出现多次。

#include <iostream>
#include <vector>
#include <unordered_set>
#include <algorithm>
#include <limits>
#include <string>

using namespace std;

int main() {
    int n, m;
    cin >> n >> m;
    
    string loves;
    cin.ignore();
    getline(cin, loves);
    unordered_set<char> loves_set(loves.begin(), loves.end());
    
    string inputs;
    getline(cin, inputs);
    
    vector<int> loves_indexes;
    for (int i = 0; i < inputs.length(); ++i) {
        if (loves_set.find(inputs[i]) != loves_set.end()) {
            loves_indexes.push_back(i);  // 如果 inputs 中的字符存在于 loves_set 中,记录其索引。
        }
    }
    
    for (int i = 0; i < inputs.length(); ++i) {
      

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

本专栏主要发布2025届嵌入式软件开发相关岗位笔试真题(嵌入式软件开发、通用软件开发、C/C++软件开发、算法工程师、测试开发等)主要是算法编程题,其中一些岗位笔试含有对应的选择题、填空题、简单题。

全部评论
网页打不开咋回事
2 回复 分享
发布于 2024-03-22 12:16 江西
得物等春招合集看看帖
1 回复 分享
发布于 2024-03-21 08:38 陕西
感谢分享
点赞 回复 分享
发布于 2024-04-22 19:14 广东
mark
点赞 回复 分享
发布于 2024-04-21 11:50 广东
买了笔记打不开
点赞 回复 分享
发布于 2024-03-25 17:35 四川
第二个没有考虑全, 输入4 1 3 7 1 1 2 2 输出5(应该是6)
点赞 回复 分享
发布于 2024-03-22 15:57 湖北

相关推荐

首先声明:以下为笔者个人看法,仅供参考,如果你觉得不对,直接别看。之前和粉丝聊过学习路线的问题,发现还是有一些误区存在--同时学linux和mcu方向。这本身没有什么问题,毕竟多学一点也没有毛病。但是由于两个方向的应用场景不同,这就导致无法在同一份工作既做Linux,又做mcu;并且对于大多数人来说,无法同时精通这两个方向,还需要花费大量时间。因此,如果在时间不充裕的情况下,挑一个方向去学习就够了,不需要两个都学。那么接下来分别说一下两个方向:mcu方向(也称为嵌入式软硬件方向)更专注于软硬件结合,也就是说除了软件部分之外,还需要懂硬件,基本的要求是要能看的懂电路原理图和PCB。如果在软件和硬件分的没那么开的公司,作为一名嵌入式软件工程师,不仅要自己写代码,还需要自己画原理图,画PCB。在软硬件分开的情况下,基本要求是要能看的懂电路原理图。这也是大多数人缺乏的点,为什么没offer,为什么没面试,这就是原因。如果你没学历,那只能卷技术(软件和硬件),将自己提高到入门工程师的水平,这样你才能拿到offer,因此建议大家做项目不要只去找开源代码,把别人代码看懂就完事了,而是要自己去把原理图看懂,把硬件焊出来,自己再去把软件部分调通,这才是企业希望看到的项目。linux方向由于岗位较少,通常需要驱动/内核/应用一起做,仅有部分公司或者原厂才会放出单一的岗位出来,如单独的linux驱动岗位,内核/应用岗位等,这个方向可能对硬件能力的要求较低。由于岗位较少,因此门槛就稍微高一些。上述就是笔者对嵌入式两个方向的看法,仅供参考。最后多说一句的是,简历谨慎同时写linux项目和mcu项目,因为实习的时候,主管说看见同时写的,有很大可能是机构出来的,可能简历无法过筛。最后,如果有需要《STM32➕RTOS项目》、《嵌入式八股文合集》及《Freertos开发手册》等资料,也可以私信笔者获取。
点赞 评论 收藏
分享
评论
14
43
分享

创作者周榜

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