算法学习——华为机考题库9(HJ56 - HJ63)

news2024/12/24 21:57:48

算法学习——华为机考题库9(HJ56 - HJ63)

HJ56 完全数计算

描述

完全数(Perfect number),又称完美数或完备数,是一些特殊的自然数。

它所有的真因子(即除了自身以外的约数)的和(即因子函数),恰好等于它本身。

例如:28,它有约数1、2、4、7、14、28,除去它本身28外,其余5个数相加,1+2+4+7+14=28。

输入n,请输出n以内(含n)完全数的个数。

数据范围: 1≤n≤5×10 5

输入描述:
输入一个数字n

输出描述:
输出不超过n的完全数的个数

示例

在这里插入图片描述

代码解释

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

//如果p是质数,且2^p-1也是质数,那么(2^p-1)X2^(p-1)便是一个完全数。

bool is_prime(int num) //判断质数
{
    for(int i=2 ; i< sqrt(num) ; i++)
    {
        if(num % i == 0) return false;
    }
    return true;
}

int main() {
    int n , result = 0 ;
    cin>>n;

    for(int i=2 ; i<sqrt(n) ; i++)
    {
        int tmp = pow(2, i) - 1;
        if(is_prime(i) && is_prime(tmp))
        {
            int prefect = pow(2,i-1) * tmp;
            if(prefect > 0 && prefect < n) result ++;
        }
    }
    cout<<result;
}
// 64 位输出请用 printf("%lld")

HJ57 高精度整数加法

描述

输入两个用字符串 str 表示的整数,求它们所表示的数之和。

数据范围: 1≤len(str)≤10000
输入描述:
输入两个字符串。保证字符串只含有’0’~'9’字符

输出描述:
输出求和后的结果

示例

在这里插入图片描述

代价解析

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

int main() {
    string str1 , str2;
    cin>>str1>>str2;
    stack<int> mystack;

    reverse(str1.begin(), str1.end());
    reverse(str2.begin(), str2.end());

    int i;
    for(i=0 ; i< max(str1.size() , str2.size()) ; i++)
    {
        int tmp;
        if( i<str1.size() &&  i< str2.size())
        {
            tmp = str1[i] - '0' +  str2[i] - '0';
            mystack.push(tmp);

        }else if( i<str1.size() &&  i >= str2.size())
        {
            tmp = str1[i] - '0';
            mystack.push(tmp);
        }else if( i >= str1.size() &&  i < str2.size())
        {
            tmp = str2[i] - '0';
            mystack.push(tmp);
        }

    }

    vector<int> num;
    string result;

    while(mystack.size() > 0)
    {
        num.push_back( mystack.top() );
        mystack.pop();
    }

    for(int i=num.size()-1 ; i>0 ; i--)
    {
        if(num[i] >= 10) 
        {
            int tmp = num[i];
            num[i] = tmp %10;
            num[i-1] += tmp / 10; 
        }
    }

    for(auto it:num) cout<<it;




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

HJ58 输入n个整数,输出其中最小的k个

描述

输入n个整数,找出其中最小的k个整数并按升序输出

本题有多组输入样例

数据范围: 1≤n≤1000 ,输入的整数满足 1≤val≤10000
输入描述:
第一行输入两个整数n和k
第二行输入一个整数数组

输出描述:
从小到大输出最小的k个整数,用空格分开。

示例

在这里插入图片描述

代码解释

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

int main() {
    int n, k;
    cin >> n >> k;
    vector<int> nums;
    int tmp;
    while(n--) 
    {   
        cin>>tmp;
        nums.push_back(tmp);
    }

    sort(nums.begin(), nums.end());

    for(int i=0 ; i<k ;i++)
        cout<<nums[i]<<' ';
}
// 64 位输出请用 printf("%lld")

HJ59 找出字符串中第一个只出现一次的字符

描述

找出字符串中第一个只出现一次的字符

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

输入描述:
输入一个非空字符串

输出描述:
输出第一个只出现一次的字符,如果不存在输出-1

示例

在这里插入图片描述

代码解析

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

int main() {
    string str;
    cin>>str;
    vector<int> myvec(26,0);

    for(int i=0 ; i < str.size() ; i++)
    {
        myvec[ str[i] - 'a' ]  += 1 ;
    }
       
    bool flag = false;
    for(int i=0 ; i<str.size() ; i++)
    {
         if(myvec[str[i] - 'a'] == 1) 
         {
            flag = true;
            cout<< str[i];
            break;
         }
    }

    if(flag == false) cout<<"-1";
        
}
// 64 位输出请用 printf("%lld")

HJ60 查找组成一个偶数最接近的两个素数

描述

任意一个偶数(大于2)都可以由2个素数组成,组成偶数的2个素数有很多种情况,本题目要求输出组成指定偶数的两个素数差值最小的素数对。

**数据范围:**输入的数据满足 4≤n≤1000
输入描述:
输入一个大于2的偶数

输出描述:
从小到大输出两个素数

示例

在这里插入图片描述

代码解释

#include <iostream>
using namespace std;

bool cheak( int num )
{
    for(int i=2 ; i<num ; i++)
    {
        if(num%i == 0) return false;
    }
    return true;
}

int main() {
    int num;
    cin>>num;
    int low,hight;

    for(int i=num/2 ; i>=2 ; i--)
    {
        if( cheak(i) == true )
        {
            low = i;
            if(cheak( num - low) == true)
            {
                hight = num - low;
                cout<<low<<endl;
                cout<<hight<<endl;
                return 0;
            }
        }
    }


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

HJ61 放苹果

描述

把m个同样的苹果放在n个同样的盘子里,允许有的盘子空着不放,问共有多少种不同的分法?
注意:如果有7个苹果和3个盘子,(5,1,1)和(1,5,1)被视为是同一种分法。

**数据范围:**0≤m≤10 ,1≤n≤10 。

输入描述:
输入两个int整数

输出描述:
输出结果,int型

示例

在这里插入图片描述

代码解释

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

int m , n;

int track( int m , int n )
{
    if(m<0||n<0) return 0;
    else if(m==1 || n==1) return 1;
    else return track(m, n-1) + track(m-n,  n) ;
}

int main() {
    
    cin>>m>>n;
    cout<<track(m, n);
}
// 64 位输出请用 printf("%lld")

HJ62 查找输入整数二进制中1的个数

描述

输入一个正整数,计算它在二进制下的1的个数。
注意多组输入输出!!!!!!

数据范围: 1≤n≤2 31−1
输入描述:
输入一个整数

输出描述:
计算整数二进制中1的个数

示例

在这里插入图片描述

代码解析

#include <iostream>
using namespace std;

int main() {
    int num;
    while(cin>>num)
    {
        int result = 0;
        for(int i=0 ; i<32 ; i++)
        {   
            if( ((num>>i) & 0x01 )== 1) result++;
        }
        cout<<result<<endl;;
    }
   

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

HJ63 DNA序列

描述

一个 DNA 序列由 A/C/G/T 四个字母的排列组合组成。 G 和 C 的比例(定义为 GC-Ratio )是序列中 G 和 C 两个字母的总的出现次数除以总的字母数目(也就是序列长度)。在基因工程中,这个比例非常重要。因为高的 GC-Ratio 可能是基因的起始点。

给定一个很长的 DNA 序列,以及限定的子串长度 N ,请帮助研究人员在给出的 DNA 序列中从左往右找出 GC-Ratio 最高且长度为 N 的第一个子串。
DNA序列为 ACGT 的子串有: ACG , CG , CGT 等等,但是没有 AGT , CT 等等

**数据范围:**字符串长度满足 1≤n≤1000 ,输入的字符串只包含 A/C/G/T 字母
输入描述:
输入一个string型基因序列,和int型子串的长度

输出描述:
找出GC比例最高的子串,如果有多个则输出第一个的子串

示例

在这里插入图片描述

代码解析

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

float cheack( string &str , int left , int right) 
{
    int num = 0;
    for(int i=left ; i<=right ; i++)
    {
        if(str[i] == 'C' || str[i] == 'G') num++;
    }
    return (float)num/(right-left + 1);
}

int main() {
    int n;
    string str;
    cin>>str;
    cin>>n;

    int left = 0 , right = n-1;
    float rate = 0.0;
    string result;
    for( ; right < str.size() ; right++ , left++ )
    {  
        float tmp = cheack(str, left, right);
    
        if(tmp > rate) 
        {
            rate = tmp;
            result.clear();
            result.assign(str.begin()+left, str.begin()+left+n);
        }
    }
    cout<<result;


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

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

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Android配置GitLab CI/CD持续集成,Shell版本的gitlab-runner,FastLane执行,上传蒲公英

mac环境下&#xff0c; 首选需要安装gitlab-runner和fastlane brew install gitlab-runner brew install fastlane 安装完成&#xff0c;来到我们在gitlab下新建的Android项目&#xff0c;我们开始创建gitlab-runner 1、创建runner 点开runner&#xff0c;点击新建runner …

map容器的基本概念及常用成员函数

map&#xff08;字典&#xff09;的基本概念 map是一个将一个值映射到另一个值的一种数据结构。&#xff08;即两个值之间有一一对应关系&#xff09;。 map的所有元素都是pair类型&#xff0c;pair中的第一个元素称为键值&#xff08;key&#xff09;第二个元素称为实值&…

Vue工程引入Element-ui

npm 安装ELement-ui npm i element-ui -S 于package.json中发现有“element-ui”版本号即可 引入 Element 在 main.js 中写入以下内容&#xff1a; import element-ui/lib/theme-chalk/index.css; import ElementUI from element-ui;Vue.use(ElementUI);之后根据自己的需求设计…

【Apache POI库读取Excel文件,并使用HashMap来存储和检查重复项】

目录 下面是一个示例代码,使用Apache POI库读取Excel文件,并使用HashMap来存储和检查重复项。 import org.apache.poi.ss.usermodel.*; import org.apache.poi.xssf.usermodel.XSSFWorkbook;import java.io.FileInputStream; import java.io.IOException; import java.util.…

Web html

目录 1 前言2 HTML2.1 元素(Element)2.1.1 块级元素和内联(行级)元素2.1.2 空元素 2.2 html页面的文档结构2.3 常见标签使用2.3.1 注释2.3.2 标题2.3.3 段落2.3.4 列表2.3.5 超链接2.3.6 图片2.3.7 内联(行级)标签2.3.8 换行 2.4 属性2.4.1 布尔属性 2.5 实体引用2.6 空格2.7 D…

python_ACM模式《剑指offer刷题》二叉树1

题目&#xff1a; 面试tips&#xff1a; 1. 询问是否可以使用双端队列 (看后面思路就可知为什么要问这个) 思路&#xff1a; 时复和空复都为O(n) 思路一&#xff1a;利用双端队列。总体思想是利用二叉树层序遍历(二叉树的层序遍历就是用队列dq&#xff0c;且从左往右每一层…

java高级开发 章节练习题(选择、填空、判断)

第九章 常用实用类 一. 单选题 1. (单选题)String类的equals方法&#xff0c;其作用是&#xff1a; A. 比较2个字符串对象是否为同一个对象B. 比较2个字符串对象的字符长度是否相同C. 比较2个字符串对象的首地址是否相同D. 比较2个字符串对象的字符序列是否相同 答案: D:比…

HBase 数据导入导出

HBase 数据导入导出 1. 使用 Docker 部署 HBase2. HBase 命令查找3. 命令行操作 HBase3.1 HBase shell 命令3.2 查看命名空间3.3 查看命名空间下的表3.4 新建命名空间3.5 查看具体表结构3.6 创建表 4. HBase 数据导出、导入4.1 导出 HBase 中的某个表数据4.2 导入 HBase 中的某…

2V2无人机红蓝对抗仿真

两架红方和蓝方无人机分别从不同位置起飞&#xff0c;蓝方无人机跟踪及击毁红方无人机 2020a可正常运行 2V2无人机红蓝对抗仿真资源-CSDN文库

css1字体属性

一.font-family(字体系列&#xff09; 不同字体系统用&#xff0c;隔开&#xff1b; 多个字母的字体系统用“”&#xff1b; 二.font-size&#xff08;字体大小&#xff09;&#xff08;有单位px&#xff09;&#xff08;默认字体16px&#xff09; 三.font-weight&#xff08…

大数据信用报告在线查询平台哪个好?

随着大数据技术在金融风控的运用&#xff0c;大数据信用越来越被人熟知&#xff0c;由于线下没有查询大数据信用的地方&#xff0c;想要查询大数据信用报告只有在线上查询&#xff0c;那大数据信用报告在线查询平台哪个好呢?本文贷你一起去了解市面上比较好的三个平台。 大数据…

Unity 渲染管线自动转换的实现 支持HDRP转URP,URP转HDRP

HDRP和URP无法平滑切换&#xff0c;因为属性、功能差异巨大。 本脚本仅对可对应的默认脚本和属性做了转换处理。细节调整还需自己搞。 自动转换可以节省手动更换shader、texture、通用属性的劳动成本。 操作步骤 使用前确保当前项目中存在HDRP和URP的包&#xff0c;没有请到p…

Vue.js 学习14 集成H265web.js播放器实现webpack自动化构建

Vue.js 学习14 集成H265web.js播放器实现webpack自动化构建 一、项目说明1. H265web.js 简介2. 准备环境 二、项目配置1. 下载 H265web.js2. 在vue项目里引入 H265web3. 设置 vue.config.js 三、代码引用1. 参照官方demo &#xff0c; 创建 executor.js2. 在 vue 页面里引用htm…

批量检测微信小程序是否封禁接口源码

<?php // 要检测的 appid 列表 $appids array(appid1, appid2, appid3); // 使用实际的 appid // 循环调用接口检测小程序状态 foreach ($appids as $appid) { $url https://yan.changxunwangluo.cn/xcx/check_mini_program.php?appid . urlencode($appid); $…

【已解决】c++ qt选中该行为什么该列部分变色

笔者开启了QTableView中交替行改变颜色&#xff0c;发现笔者自定义绘制的水平滚动条&#xff0c;在选中后不发生颜色改变&#xff0c;这让笔者很疑惑。笔者查阅资料后发现&#xff0c;自定义绘制的控件&#xff0c;要自身设置颜色。当笔者解决了这个问题时&#xff0c;顺手就将…

GPT原始论文:Improving Language Understanding by Generative Pre-Training论文翻译

1 摘要 自然语理解包括文本蕴含、问题回答、语义相似性评估和文档分类等一系列多样化的任务。尽管大量未标注的文本语料库很丰富&#xff0c;但用于学习这些特定任务的标注数据却很稀缺&#xff0c;这使得基于区分性训练的模型难以充分发挥作用。我们展示了通过在多样化的未标…

高级Java开发工程师岗位的基本职责(合集)

高级Java开发工程师岗位的基本职责1 职责&#xff1a; 1、负责区块链产品的研发&#xff0c;独立或与团队合作&#xff0c;按时保质完成软件开发项目; 2、参与产品系统设计、概要设计工作&#xff0c;核心功能的代码编写; 3、独立解决和指导其他同事处理开发中遇到的难点问题; …

GaussDB新体验,新零售选品升级注入新思路【华为云GaussDB:与数据库同行的日子】

选品思维&#xff1a;低频VS高频 一个的商超&#xff0c;假设有50个左右的品类&#xff0c;每个品类下有2到10个不等的商品。然而如此庞大的商品&#xff0c;并非所有都是高频消费品。 结合自身日常的消费习惯&#xff0c;对于高频和低频的区分并不难。一般大型家电、高端礼盒…

14.2 Java正则表达式(❤❤)

14.2 Java正则表达式 1. 正则表达式1.1 简介1.2 字符范围匹配1.3 元字符1.4 多次重复匹配1.5 定位匹配1.6 贪婪模式与非贪婪模式1.7 表达式分组1. 正则表达式 1.1 简介 开源 在线正则表达式测试 1.2 字符范

mapbox 高亮相同特征的要素数据

一、完整代码 <!DOCTYPE html> <html> <head> <meta charset"utf-8"> <title>Highlight features containing similar data</title> <meta name"viewport" content"initial-scale1,maximum-scale1,user-scal…