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

算法学习——华为机考题库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.mzph.cn/news/668009.shtml

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

相关文章

C# CAD界面-自定义工具栏(二)

运行环境 vs2022 c# cad2016 调试成功 一、引用 acdbmgd.dllacmgd.dllaccoremgd.dllAutodesk.AutoCAD.Interop.Common.dllAutodesk.AutoCAD.Interop.dll using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Threading.T…

【pwn】pwnable_start --只有read和write函数的getshell

首先查一下程序的保护情况 保护全关&#xff01;&#xff01;&#xff01; 然后看ida逻辑 ida的结果很简洁&#xff0c;只有一段汇编代码&#xff0c;我们再来看看nc情况 现在我们来分析一下汇编代码 mov ecx, esp ; addr .text:08048089 B2 14 …

Fink CDC数据同步(六)数据入湖Hudi

数据入湖Hudi Apache Hudi(简称&#xff1a;Hudi)使得您能在hadoop兼容的存储之上存储大量数据&#xff0c;同时它还提供两种原语&#xff0c;使得除了经典的批处理之外&#xff0c;还可以在数据湖上进行流处理。这两种原语分别是&#xff1a; Update/Delete记录&#xff1a;H…

LLaVA:GPT-4V(ision) 的新开源替代品

LLaVA&#xff1a;GPT-4V(ision) 的新开源替代品。 LLaVA &#xff08;https://llava-vl.github.io/&#xff0c;是 Large Language 和Visual A ssistant的缩写&#xff09;。它是一种很有前景的开源生成式 AI 模型&#xff0c;它复制了 OpenAI GPT-4 在与图像对话方面的一些功…

arping交叉编译

arping命令依赖libpcap和libnet&#xff0c;需要先交叉编译这两个库。 1.交叉编译libpcap 下载libpcap源文件&#xff0c;从github上克隆: git clone https://github.com/the-tcpdump-group/libpcap.git source交叉编译环境 # environment-setup是本机的交叉编译环境, 里面…

LabVIEW风力发电机在线监测

LabVIEW风力发电机在线监测 随着可再生能源的发展&#xff0c;风力发电成为越来越重要的能源形式。设计了一个基于控制器局域网&#xff08;CAN&#xff09;总线和LabVIEW的风力发电机在线监测系统&#xff0c;实现风力发电机的实时监控和故障诊断&#xff0c;以提高风力发电的…

windows安装Visual Studio Code,配置C/C++运行环境(亲测可行)

一.下载 Visual Studio Code https://code.visualstudio.com/ 二.安装 选择想要安装的位置: 后面的点击下一步即可。 三.下载编译器MinGW vscode只是写代码的工具&#xff0c;使用编译器才能编译写的C/C程序&#xff0c;将它转为可执行文件。 MinGW下载链接&#xff1a;…

Stable Diffusion 模型下载:国风3 GuoFeng3

文章目录 模型介绍生成案例案例一案例二案例三案例四案例五案例六案例七案例八案例九案例十推荐提示词下载地址模型介绍 欢迎使用GuoFeng3模型 - 这是一个中国华丽古风风格模型,也可以说是一个古风游戏角色模型,具有2.5D的质感。 条目内

CDH6.3.2 多 Spark 版本共存

一 部署Spark客户端 1.1 部署spark3客户端 tar -zxvf spark-3.3.1-bin-3.0.0-cdh6.3.2.tgz -C /opt/cloudera/parcels/CDH/lib cd /opt/cloudera/parcels/CDH/lib mv spark-3.3.1-bin-3.0.0-cdh6.3.2/ spark3将 CDH 集群的 spark-env.sh 复制到 /opt/cloudera/parcels/CDH/li…

C语言函数递归例子2青蛙跳台阶问题

接下来我们来看一下第二个例子青蛙跳台阶 青蛙跳台阶问题 这个问题经常在各类面试中看到。一只青蛙一次可以跳上1级台阶&#xff0c;也可以跳上2级。求该青蛙跳上一个n级的台阶总共有多少种跳法。是实践函数递归的典型问题 分析问题 我们先假设有n个台阶&#xff0c;如果n1&am…

如何构建多种系统架构支持的 Docker 镜像

如何构建多种系统架构支持的 Docker 镜像 1.概述2.解决方案3.使用manifest案例 1.概述 我们知道使用镜像创建一个容器&#xff0c;该镜像必须与 Docker 宿主机系统架构一致&#xff0c;例如 Linux x86_64 架构的系统中只能使用 Linux x86_64 的镜像创建容器 例如我们在 Linux…

PyTorch 2.2 中文官方教程(七)

使用 torchtext 库进行文本分类 原文&#xff1a;pytorch.org/tutorials/beginner/text_sentiment_ngrams_tutorial.html 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 注意 点击这里下载完整示例代码 在本教程中&#xff0c;我们将展示如何使用 torchtext 库构建文…

Vue中nextTick方法的作用与原理

在Vue的开发中&#xff0c;你可能会遇到一些异步更新的问题&#xff0c;如在改变数据后需要等待DOM更新完毕后再进行下一步操作。这时就可以使用Vue提供的nextTick方法来解决这个问题。 nextTick方法的作用是在DOM更新之后执行回调函数&#xff0c;确保在下次DOM更新循环结束之…

ReactNative实现一个圆环进度条

我们直接看效果&#xff0c;如下图 我们在直接上代码 /*** 圆形进度条*/ import React, {useState, useEffect} from react; import Svg, {Circle,G,LinearGradient,Stop,Defs,Text, } from react-native-svg; import {View, StyleSheet} from react-native;// 渐变色 const C…

PyTorch 2.2 中文官方教程(四)

torch.nn 到底是什么&#xff1f; 原文&#xff1a;pytorch.org/tutorials/beginner/nn_tutorial.html 译者&#xff1a;飞龙 协议&#xff1a;CC BY-NC-SA 4.0 注意 点击这里下载完整示例代码 作者&#xff1a; Jeremy Howard&#xff0c;fast.ai。感谢 Rachel Thomas 和 Fr…

队列---数据结构

定义 队列&#xff08;Queue&#xff09;简称队&#xff0c;也是一种操作受限的线性表&#xff0c;只允许在表的一端进行插入&#xff0c;而在表的另一端进行删除。向队列中插入元素称为入队或进队&#xff1b;删除元素称为出队或离队。 队头&#xff08;Front&#xff09;&a…

2024年Java面试题大全 面试题附答案详解,BTA内部面试题

基础篇 1、 Java语言有哪些特点 1、简单易学、有丰富的类库 2、面向对象&#xff08;Java最重要的特性&#xff0c;让程序耦合度更低&#xff0c;内聚性更高&#xff09; 阿里内部资料 基本类型 大小&#xff08;字节&#xff09; 默认值 封装类 6、Java自动装箱与拆箱 装箱就是…

Maven提示Failure to find com.oracle:ojdbc14:jar:10.2.0.4.0

目录 问题 解决方案 1、下载oracle的驱动jar包 2、安装到本地仓库 3、检查本地仓库是否成功安装 4、Maven先clean &#xff0c;再install。 问题 项目引入Oracle依赖后报错&#xff0c;显示为红色。 解决方案 1、下载oracle的驱动jar包 首先我们要去下载一个oracle的…

undefined symbol: avio_protocol_get_class, version LIBAVFORMAT_58

rv1126上进行编译和在虚拟机里面进行交叉编译ffmpeg都不行 解决办法查看 查看安装的ffmpeg链接的文件 ldd ./ffmpeg rootEASY-EAI-NANO:/home/nano/ffmpeg-4.3.6# ldd ffmpeg linux-vdso.so.1 (0xaeebd000)libavdevice.so.58 > /lib/arm-linux-gnueabihf/libavde…

哪些因素会限制带宽的可用性?

当我们讨论带宽的可用性时&#xff0c;我们主要关注的是数据传输的速度和容量。带宽就像一条公路&#xff0c;数据就像行驶在公路上的车辆&#xff0c;带宽越大&#xff0c;可以同时传输的数据就越多&#xff0c;数据传输的速度也就越快。但是&#xff0c;就像公路会有各种限制…