小奥的学习笔记

  • Home
  • Learning & Working
    • Speech Enhancement Notes
    • Programming language
    • Computer & DL
    • MOOC
  • Life
    • Life Time
    • Thinking & Comprehension
    • Volunteer
    • Plan
    • Travel
  • Footprints
  • GuestBook
  • About
    • About Me
    • 个人履历
    • 隐私策略
  1. 首页
  2. Study-notes
  3. Programming language
  4. Algorithm
  5. 正文

华为软件上机笔试(2019年8月7日)题目解答(部分)

2019年8月9日 1679点热度 0人点赞 0条评论

恕个人能力有限,所用测试用例有限,所以可能代码存在问题,如有问题,欢迎提供测试用例,我将及时做修改,非常感谢和大家一起努力学习进步。

题目1:全量字符串的剩余

假设输入一个字符串由全量字符串和已用的字符串组成,其格式为全量字符串@已用字符串。输出在全量字符串减去已用字符串的结果。例如输入a:3,B:5,c:2@B:5,c:1,则输出a:3,c:1。若没有已用字符串,则依旧表示为a:3,B:5,c:2@。对于字母仅限26个英文字母,区分大小写。字符串长度不超过100。

要求:①输出顺序不能改变(按照全量字符串的顺序输出)。②若剩余数目为0,则不输出该字符。

#include <iostream>
#include <vector>
#include <string>
using namespace std;
//切出来:和,之间的数字
int findNum(string str, int n)
{
    int res = 0;
    while ((n++) && (n<str.size()))
    {
        if (str[n] == ':')
            continue;
        if (str[n] == ',')
            break;
        if (str[n] == '@')
            break;
        if (str[n] >= '0'&&str[n] <= '9')
            res = res * 10 + (str[n] - '0');
    }

    return res;
}
//计算的主程序
string getResult(string str)
{
    vector<char> qlzifu;
    vector<int> qlzfnum;
    vector<char> zyzifu;
    int i = 0;
    string res1 = "";

    for (; i < str.size(); i++)
    {
        if (str[i] == '@')
        {
            break;
        }
        if ((str[i] >= 'a'&&str[i] <= 'z') || (str[i] >= 'A'&&str[i] <= 'Z'))
        {
            qlzifu.push_back(str[i]);
        }
        if (str[i] == ':')
            qlzfnum.push_back(findNum(str, i));
    }
    int numalpha = qlzifu.size();
    vector<int> zyzfnum;
    //处理已占用字符串
    if (i != str.size() - 1)
    {
        for (; i < str.size(); i++)
        {
            if ((str[i] >= 'a'&&str[i] <= 'z') || (str[i] >= 'A'&&str[i] <= 'Z'))
            {
                zyzifu.push_back(str[i]);
            }
            if (str[i] == ':')
                zyzfnum.push_back(findNum(str, i));

        }
    }

    //补充零
    int qianque = qlzifu.size() - zyzfnum.size();
    while (qianque--)
    {
        zyzfnum.push_back(0);
    }

    vector<int>res;
    for (int m = 0; m < qlzifu.size(); m++)
    {
        for (int zyi = 0; zyi < zyzifu.size(); zyi++)
        {
            if (qlzifu[m] == zyzifu[zyi])
                res.push_back(qlzfnum[m] - zyzfnum[zyi]);

        }
        res.push_back(qlzfnum[m]);

    }
    for (int no = 0; no < qlzifu.size(); no++)
    {
        if (res[no] <= 0)
            continue;
        string stmp(1, qlzifu[no]);
        res1.append(stmp);
        res1.append(":");
        res1.append(to_string(res[no]));
        if (no < qlzifu.size() - 1)
            res1.append(",");
    }

    return res1;
}

int main() {
    string str;
    string res = getResult(str);
    cout << res << endl;
    return 0;
}

题目2:省略

(未做出,待补充)

题目3:逻辑表达式

(待补充)

本作品采用 知识共享署名 4.0 国际许可协议 进行许可
标签: 暂无
最后更新:2019年8月9日

davidcheung

这个人很懒,什么都没留下

打赏 点赞
< 上一篇

文章评论

razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
取消回复

搜索
欢迎关注我的个人公众号
最新 热点 随机
最新 热点 随机
DEEPFILTERNET:一种基于深度滤波的全频带音频低复杂度语音增强框架 奥地利匈牙利九日游旅程 论文阅读之Study of the General Kalman Filter for Echo Cancellation 小奥看房之鸿荣源珈誉府 杭州往返旅途及西溪喜来登和万怡的体验报告 2022年的第一篇碎碎念
奥地利匈牙利九日游旅程小奥看房之鸿荣源珈誉府论文阅读之Study of the General Kalman Filter for Echo CancellationDEEPFILTERNET:一种基于深度滤波的全频带音频低复杂度语音增强框架
2010 S.V Beijing Travel Ready:Ticket 国家文物局关于齐长城遗址保护范围和建设控制地带内济南至莱芜高速铁路建设项目的意见 沉痛哀悼在COVID-19疫情中逝去的战士和患者 计算机组成原理笔记第七章(7.1~7.2) Java语言程序设计【学堂在线】编程作业(第三章) 反思111111
标签聚合
算法 高中 leetcode 学习 生活 鸟哥的linux私房菜 Python python学习 linux Java
最近评论
davidcheung 发布于 5 个月前(02月09日) The problem has been fixed. May I ask if you can s...
tk88 发布于 5 个月前(02月07日) Hmm is anyone else having problems with the pictur...
cuicui 发布于 9 个月前(10月20日) :wink:
niming 发布于 10 个月前(09月19日) 同级校友,能刷到太巧了
davidcheung 发布于 2 年前(08月16日) 我得找一下我之前整理的word文档看一下,如果找到了我就更新一下这篇文章。
Nolan 发布于 2 年前(07月25日) 您的笔记非常有帮助。贴图不显示了,可以更新一下吗?
davidcheung 发布于 3 年前(06月19日) 到没有看webrtc的代码。现在主要在看我们公司的代码了。。。只是偶尔看一看webrtc的东西。。。
aobai 发布于 3 年前(03月13日) gain_change_hangover_ 应该是每三个block 只能够调整一次,这样保证每帧...
匿名 发布于 5 年前(12月30日) 烫
小奥 发布于 5 年前(12月12日) webRTC里面的NS本身我记得就是在C++里面呀

COPYRIGHT © 2025 小奥的学习笔记. ALL RIGHTS RESERVED.

Theme Kratos Made By Seaton Jiang

陕ICP备19003234号-1

鲁公网安备37120202000100号