算法学习——华为机考题库4(HJ26 - HJ30)

算法学习——华为机考题库4(HJ26 - HJ30)

HJ26 字符串排序

描述

编写一个程序,将输入字符串中的字符按如下规则排序。

规则 1 :英文字母从 A 到 Z 排列,不区分大小写。

如,输入: Type 输出: epTy

规则 2 :同一个英文字母的大小写同时存在时,按照输入顺序排列。

如,输入: BabA 输出: aABb

规则 3 :非英文字母的其它字符保持原来的位置。

如,输入: By?e 输出: Be?y

**数据范围:**输入的字符串长度满足 1≤n≤1000

输入描述:
输入字符串
输出描述:
输出字符串

示例

在这里插入图片描述

代码解析

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

static bool cmp(pair<char,int> &p1, pair<char,int> &p2)
{
    int c1 = p1.first , c2 = p2.first;
    int i1 , i2;
    if(c1 >= 'a' && c1 <= 'z') i1 = c1 - 'a';
    else i1 = c1 - 'A';

    if(c2 >= 'a' && c2 <= 'z') i2 = c2 - 'a';
    else i2 = c2 - 'A';

    if(i1 < i2) return true;
    else if(i1 > i2) return false;
   
    return p1.second < p2.second;
}

int main() {
    string tmpStr;
    vector<pair<char,int>> tmpVec;
    getline(cin, tmpStr);
   
    for (int i=0 ; i<tmpStr.size() ; i++)
    {
        if( (tmpStr[i] >= 'A' && tmpStr[i] <= 'Z') 
            || (tmpStr[i] >= 'a' && tmpStr[i] <= 'z') )
        tmpVec.push_back({tmpStr[i],i});
    }
    sort(tmpVec.begin(), tmpVec.end(),cmp);

    int indnx = 0;
    for (int i=0 ; i<tmpStr.size() ; i++)
    {
        if( (tmpStr[i] >= 'A' && tmpStr[i] <= 'Z') 
            || (tmpStr[i] >= 'a' && tmpStr[i] <= 'z') )
        {
            tmpStr[i] = tmpVec[indnx].first;
            indnx++;
        }
    }
    cout<<tmpStr;

}
// 64 位输出请用 printf("%lld")

HJ27 查找兄弟单词

描述

定义一个单词的“兄弟单词”为:交换该单词字母顺序(注:可以交换任意次),而不添加、删除、修改原有的字母就能生成的单词。
兄弟单词要求和原来的单词不同。例如: ab 和 ba 是兄弟单词。 ab 和 ab 则不是兄弟单词。
现在给定你 n 个单词,另外再给你一个单词 x ,让你寻找 x 的兄弟单词里,按字典序排列后的第 k 个单词是什么?
注意:字典中可能有重复单词。

数据范围: 1≤n≤1000 ,输入的字符串长度满足 1≤len(str)≤10 , 1≤k<n
输入描述:
输入只有一行。 先输入字典中单词的个数n,再输入n个单词作为字典单词。 然后输入一个单词x 最后后输入一个整数k
输出描述:
第一行输出查找到x的兄弟单词的个数m 第二行输出查找到的按照字典顺序排序后的第k个兄弟单词,没有符合第k个的话则不用输出。

示例

在这里插入图片描述

代码解析

#include <algorithm>
#include <iostream>
#include <set>

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

bool cheak(string aim , string date)
{
    if(aim == date) return false;
    multiset<char> aimSet;
    multiset<char> dateSet;

    for(int i=0 ; i<aim.size() ;i++)
        aimSet.insert(aim[i]);

    for(int i=0 ; i<date.size() ;i++)
        dateSet.insert(date[i]);
    
    if(aimSet == dateSet) return true;
    else return false;
    
}

int main() {
    int num;
    vector<string> date;
    vector<string> result;
    cin>>num;
    string tmpStr;
    while(num--) 
    {
        cin>>tmpStr;
        date.push_back(tmpStr);
    }
    string aim;
    cin>>aim;
    int k;
    cin>>k;
    k -= 1;

    for(int i=0 ; i<date.size() ; i++)
    {
        if(cheak(aim, date[i]) == true)
            result.push_back(date[i]);
    }

    sort(result.begin(), result.end());
    cout<<result.size()<<endl;
    if(result.size() > k) cout<<result[k];

}
// 64 位输出请用 printf("%lld")

HJ28 素数伴侣

描述

题目描述
若两个正整数的和为素数,则这两个正整数称之为“素数伴侣”,如2和5、6和13,它们能应用于通信加密。现在密码学会请你设计一个程序,从已有的 N ( N 为偶数)个正整数中挑选出若干对组成“素数伴侣”,挑选方案多种多样,例如有4个正整数:2,5,6,13,如果将5和6分为一组中只能得到一组“素数伴侣”,而将2和5、6和13编组将得到两组“素数伴侣”,能组成“素数伴侣”最多的方案称为“最佳方案”,当然密码学会希望你寻找出“最佳方案”。

输入:

有一个正偶数 n ,表示待挑选的自然数的个数。后面给出 n 个具体的数字。

输出:

输出一个整数 K ,表示你求得的“最佳方案”组成“素数伴侣”的对数。

数据范围: 1≤n≤100 ,输入的数据大小满足 2≤val≤30000
输入描述:
输入说明
1 输入一个正偶数 n
2 输入 n 个整数

输出描述:
求得的“最佳方案”组成“素数伴侣”的对数。

示例

在这里插入图片描述

代码解析

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

bool isprime(int num)//判断一个数是否是素数
{ 
    for(int i = 2; i * i <= num; i++)//遍历到根号num
    { 
        if(num % i == 0) //检查有无余数
            return false;
    }
    return true;
}

bool find(int num, vector<int>& evens, vector<bool>& used, vector<int>& match)
{
    for(int i = 0; i < evens.size(); i++)//遍历每个偶数与奇数比较
    { 
        if(isprime(num + evens[i]) && used[i] == false)
        {
            used[i] = true;
            if(match[i] == 0 || find(match[i], evens, used, match) == true)//如果第i个偶数还未配对,或者跟它配对的奇数还有别的选择
            { 
                match[i] = num; //则配对该数
                return true;
            }
        }
    }
    return false;
}
int main(){
    int n;
    cin >> n;
    
    vector<int> odds;
    vector<int> evens;
    vector<int> nums(n);
    for(int i = 0; i < n; i++)//输入n个数
    { 
        cin >> nums[i];
        if(nums[i] % 2) //奇数
            odds.push_back(nums[i]);
        else //偶数
            evens.push_back(nums[i]);
    }

    int count = 0;
    if(odds.size() == 0 || evens.size() == 0)//缺少奇数或者偶数无法构成素数
    { 
        cout << count << endl;
        return 0;
    }

    vector<int> match(evens.size(), 0); //统计每个偶数的配对是哪个奇数
    for(int i = 0; i < odds.size(); i++)//遍历每个奇数
    { 
        vector<bool> used(evens.size(), false); //每一轮偶数都没用过
        if(find(odds[i], evens, used, match) == true) //能否找到配对的偶数,且要最优
            count++;
    }
    cout << count << endl;
    
    return 0;
}

HJ29 字符串加解密

描述

对输入的字符串进行加解密,并输出。

加密方法为:

当内容是英文字母时则用该英文字母的后一个字母替换,同时字母变换大小写,如字母a时则替换为B;字母Z时则替换为a;

当内容是数字时则把该数字加1,如0替换1,1替换2,9替换0;

其他字符不做变化。

解密方法为加密的逆过程。
数据范围:输入的两个字符串长度满足 1≤n≤1000 ,保证输入的字符串都是只由大小写字母或者数字组成
输入描述:
第一行输入一串要加密的密码
第二行输入一串加过密的密码

输出描述:
第一行输出加密后的字符
第二行输出解密后的字符

示例

在这里插入图片描述

代码解析

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

void code(string &tmp)
{
    for(int i=0 ; i <tmp.size() ; i++)
    {
        if(tmp[i] >= 'a' && tmp[i] < 'z') cout<< (char)(tmp[i] - 'a' + 'A' + 1);
        else if( tmp[i] == 'z') cout<<'A';
        else if(tmp[i] >= 'A' && tmp[i] < 'Z') cout<< (char)(tmp[i] - 'A' + 'a' + 1);
        else if( tmp[i] == 'Z') cout<<'a';
        else if(tmp[i] >= '0' && tmp[i] < '9') cout<<(char)(tmp[i] + 1);
        else if( tmp[i] == '9') cout<<'0';
    }
}

void uncode(string &tmp)
{
    for(int i=0 ; i <tmp.size() ; i++)
    {
        if(tmp[i] > 'a' && tmp[i] <= 'z') cout<< (char)(tmp[i] - 'a' + 'A' - 1);
        else if( tmp[i] == 'a') cout<<'Z';
        else if(tmp[i] > 'A' && tmp[i] <= 'Z') cout<< (char)(tmp[i] - 'A' + 'a' - 1);
        else if( tmp[i] == 'A') cout<<'z';
        else if(tmp[i] > '0' && tmp[i] <= '9') cout<<(char)(tmp[i] - 1);
        else if( tmp[i] == '0') cout<<'9';
    }
}

int main() {
    string Str1;
    string Str2;
    cin>>Str1;
    cin>>Str2;
    code(Str1);
    cout<<endl;
    uncode(Str2);

}
// 64 位输出请用 printf("%lld")

HJ30 字符串合并处理

描述

按照指定规则对输入的字符串进行处理。

详细描述:

第一步:将输入的两个字符串str1和str2进行前后合并。如给定字符串 “dec” 和字符串 “fab” , 合并后生成的字符串为 “decfab”

第二步:对合并后的字符串进行排序,要求为:下标为奇数的字符和下标为偶数的字符分别从小到大排序。这里的下标的意思是字符在字符串中的位置。注意排序后在新串中仍需要保持原来的奇偶性。例如刚刚得到的字符串“decfab”,分别对下标为偶数的字符’d’、‘c’、‘a’和下标为奇数的字符’e’、‘f’、'b’进行排序(生成 ‘a’、‘c’、‘d’ 和 ‘b’ 、‘e’ 、‘f’),再依次分别放回原串中的偶数位和奇数位,新字符串变为“abcedf”

第三步:对排序后的字符串中的’0’‘9’、‘A’‘F’和’a’~'f’字符,需要进行转换操作。
转换规则如下:
对以上需要进行转换的字符所代表的十六进制用二进制表示并倒序,然后再转换成对应的十六进制大写字符(注:字符 a~f 的十六进制对应十进制的10~15,大写同理)。
如字符 ‘4’,其二进制为 0100 ,则翻转后为 0010 ,也就是 2 。转换后的字符为 ‘2’。
如字符 ‘7’,其二进制为 0111 ,则翻转后为 1110 ,对应的十进制是14,转换为十六进制的大写字母为 ‘E’。
如字符 ‘C’,代表的十进制是 12 ,其二进制为 1100 ,则翻转后为 0011,也就是3。转换后的字符是 ‘3’。
根据这个转换规则,由第二步生成的字符串 “abcedf” 转换后会生成字符串 “5D37BF”。

**数据范围:**输入的字符串长度满足 1≤n≤100

输入描述:
样例输入两个字符串,用空格隔开。

输出描述:
输出转化后的结果。

示例

在这里插入图片描述

代码解析

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


//字典法:只考虑 '0' 到 '9' ,'a' 到 'f','A' 到 'F' 的字符即可,其余字符不做改变,照原输出
string Intput ="0123456789abcdefABCDEF"; //输入参照字典(数字 + 大小写字母)
//    int Output[] = "084c2a6e195d3b7f5d3b7f"; //输出参照字典(小写)
string Output = "084C2A6E195D3B7F5D3B7F"; //输出参照字典(数字 + 大写字母)
char code( char &tmpChar)
{
    int indnx = Intput.find(tmpChar);
    if(indnx != -1)  return Output[ indnx ];
    else return tmpChar;
   
}

int main() {
    string Str1 , Str2;
    cin>>Str1>>Str2;
    string Str = Str1 + Str2;
    vector<char> even;
    vector<char> odd;
    for(int i=0 ; i<Str.size() ; i++)
    {
        if(i%2 == 0) even.push_back(Str[i]);
        else odd.push_back(Str[i]);
    }

    sort(even.begin(), even.end());
    reverse(even.begin(),even.end());
    sort(odd.begin(), odd.end());
    reverse(odd.begin(),odd.end());

    for(int i=0 ; i<Str.size() ; i++)
    {
        if(i%2 == 0)
        {
            Str[i] = even.back();
            even.pop_back();
        } 
        else 
        {
            Str[i] = odd.back();
            odd.pop_back();
        }
    }
    // cout<<Str<<endl;

    for(int i=0 ; i<Str.size() ; i++)
    {
        Str[i] = code(Str[i]);
    }
    cout<<Str<<endl;
    
}
// 64 位输出请用 printf("%lld")

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/367872.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

2024年 复习 HTML5+CSS3+移动web 笔记 之CSS遍 第5天

第 五 天 整个网站例 5.1 准备工作 项目目录与版心 base.css 5.2 网页制作思路 5.3 header 区域-整体布局 5.4 header区域-logo 5.5 header区域-导航 index.html <!DOCTYPE html> <html lang"en"> <head><meta charset"UTF-8">&l…

qt -chart控件设计器可拖拉

qt -chart控件设计器可拖拉 一、演示效果二、安装过程三、核心程序四、程序链接 一、演示效果 二、安装过程 三、核心程序 #include <QtGui> #include <QColor>#include <cstdlib> #include <cassert> #include <numeric>#include <chartwor…

Python 数据分析(PYDA)第三版(六)

原文&#xff1a;wesmckinney.com/book/ 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 十二、Python 建模库介绍 原文&#xff1a;wesmckinney.com/book/modeling 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 此开放访问网络版本的《Python 数据分析第三版…

如何在win系统部署开源云图床Qchan并无公网ip访问本地存储图片

文章目录 前言1. Qchan网站搭建1.1 Qchan下载和安装1.2 Qchan网页测试1.3 cpolar的安装和注册 2. 本地网页发布2.1 Cpolar云端设置2.2 Cpolar本地设置 3. 公网访问测试总结 前言 图床作为云存储的一项重要应用场景&#xff0c;在大量开发人员的努力下&#xff0c;已经开发出大…

01-Java工厂模式 ( Factory Pattern )

工厂模式 Factory Pattern 摘要实现范例 工厂模式&#xff08;Factory Pattern&#xff09;提供了一种创建对象的最佳方式 工厂模式在创建对象时不会对客户端暴露创建逻辑&#xff0c;并且是通过使用一个共同的接口来指向新创建的对象 工厂模式属于创建型模式 摘要 1. 意图 …

Mac M1使用PD虚拟机运行win10弹出“内部版本已过期立即安装新的windows内部版本”

一、问题 内部版本已过期立即安装新的windows内部版本 二、解决 1、如图所示打开zh-CN目录 C:\windows\system32\zh-CN找到licensingui.exe文件 将该文件重命名为licensingui_bak.exe 2、修改完成效果如下 &#xff08;1&#xff09;但操作中发现&#xff0c;需要TrustedIns…

店群如何防关联?抖音小店被限流怎么办?——站斧浏览器云桌面

无论是抖音小店店铺&#xff0c;还是其他店铺&#xff1b;使用相同法人、相同类目&#xff0c;多开都会被限流&#xff0c;甚至严重到全部店铺迟迟不出单。 下面小编根据不同情况给出解决方案&#xff1a; 1.不同法人、相同类目的情况 使用云服务器&#xff08;站斧云桌面&am…

webpack配置

一、很多基础方面的配置被vuecli所集成一般项目都是使用vuecli,不会真正的去从0-1进行webpack配置: 1、vuecli中的webpack基础配置: (1)入口文件默认在src/main;输出在dist; (2)集成了大量的插件和加载器:babel-loader 处理 JavaScript 文件、使用 css-loader 和 style-load…

简单说说redis分布式锁

什么是分布式锁 分布式锁&#xff08;多服务共享锁&#xff09;在分布式的部署环境下&#xff0c;通过锁机制来让多客户端互斥的对共享资源进行访问/操作。 为什么需要分布式锁 在单体应用服务里&#xff0c;不同的客户端操作同一个资源&#xff0c;我们可以通过操作系统提供…

Jupyter Notebook中的%matplotlib inline详解

Jupyter Notebook中的%matplotlib inline详解 &#x1f335;文章目录&#x1f335; &#x1f333;引言&#x1f333;&#x1f333;什么是魔术命令&#x1f333;&#x1f333;%matplotlib inline详解&#x1f333;(&#x1f448;直入主题请点击)&#x1f333;小结&#x1f333;&…

【乳腺肿瘤诊断分类及预测】基于Elman神经网络

课题名称&#xff1a;基于Elman神经网络的乳腺肿瘤诊断分类及预测 版本日期&#xff1a;2023-05-15 运行方式: 直接运行Elman0501.m 文件即可 代码获取方式&#xff1a;私信博主或QQ&#xff1a;491052175 模型描述&#xff1a; 威斯康辛大学医学院经过多年的收集和整理&a…

前端 reduce()用法总结

定义 reduce()方法对数组中的每个元素执行一个由您提供的reducer函数(升序执行)&#xff0c;将其结果汇总为单个返回值。语法为&#xff1a; array.reduce(function(accumulator, currentValue, currentIndex, arr), initialValue); /*accumulator: 必需。累计器currentValu…

Android13源码下载及全编译流程

目录 一、源码下载 1.1、配置要求 1.1.1、硬件配置要求 1.1.2、软件要求 1.2、下载环境搭建 1.2.1、依赖安装 1.2.2、工具安装 1.2.3、git配置 1.2.4、repo配置 1.3、源码下载 1.3.1、明确下载版本 1.3.2、替换为清华源 1.3.3、初始化仓库并指定分支 1.3.4、同步全部源码 二、…

运用 StringJoiner 高效的拼接字符串

运用 StringJoiner 高效的拼接字符串 package com.zhong.stringdemo;import java.util.ArrayList; import java.util.StringJoiner;public class Test {public static void main(String[] args) {ArrayList<String> s new ArrayList<>();s.add("11");s.…

二进制_八进制_十六进制和十进制之间互转(简单明了)

文章目录 二进制_八进制_十六进制和十进制之间互转&#xff08;简单明了&#xff09;二进制八进制十六进制将二进制、八进制、十六进制转换为十进制1) 整数部分2) 小数部分 将十进制转换为二进制、八进制、十六进制1) 整数部分2) 小数部分 二进制和八进制、十六进制的转换1) 二…

css新手教程

css新手教程 课程&#xff1a;14、盒子模型及边框使用_哔哩哔哩_bilibili 一.什么是CSS 1.什么是CSS Cascading Style Sheet 层叠样式表。 CSS&#xff1a;表现&#xff08;美化网页&#xff09; 字体&#xff0c;颜色&#xff0c;边距&#xff0c;高度&#xff0c;宽度&am…

git 如何修改仓库地址

问题背景&#xff1a;组内更换大部门之后&#xff0c;代码仓的地址也迁移了&#xff0c;所以原来的git仓库地址失效了。 虽然重新建一个新的文件夹&#xff0c;再把每个项目都git clone一遍也可以。但是有点繁琐&#xff0c;而且有的项目本地还有已经开发一半的代码&#xff0c…

Pandas.Series.clip() 修剪数值范围 详解 含代码 含测试数据集 随Pandas版本持续更新

关于Pandas版本&#xff1a; 本文基于 pandas2.2.0 编写。 关于本文内容更新&#xff1a; 随着pandas的stable版本更迭&#xff0c;本文持续更新&#xff0c;不断完善补充。 传送门&#xff1a; Pandas API参考目录 传送门&#xff1a; Pandas 版本更新及新特性 传送门&…

虚幻UE5Matehuman定制自己的虚拟人,从相机拍照到UE5制作全流程

开启自己的元宇宙,照片扫描真实的人类,生成虚拟形象,保姆级教程,欢迎大家指正。 需要的软件: 制作流程: 一.拍照。 围绕自己拍照,大概20多张图就差不多了,把脑门漏出来,无需拍后脑勺。 拍照方式 例如,拍照时尽量不要在脸上体现出明显的光源方向。

低版本MATLAB打开高版本Simulink文件的方法

打开simulink&#xff0c;依次点击“建模”、“环境”、“simulink预设项”&#xff0c;如图所示&#xff1a; 然后在弹出的窗口中&#xff0c;点击“模型文件”&#xff0c;并取消勾选“不要加载用更新版本的simulink创建的模型”&#xff0c;接着点击“应用”即可。如图所示&…