当前位置: 首页 > news >正文

北京做网站公司排名竞价服务托管公司

北京做网站公司排名,竞价服务托管公司,小熊猫seo博客,如何自建网站卖产品算法学习——华为机考题库10(HJ64 - HJ69) HJ64 MP3光标位置 描述 MP3 Player因为屏幕较小,显示歌曲列表的时候每屏只能显示几首歌曲,用户要通过上下键才能浏览所有的歌曲。为了简化处理,假设每屏只能显示4首歌曲&a…

算法学习——华为机考题库10(HJ64 - HJ69)

HJ64 MP3光标位置

描述

MP3 Player因为屏幕较小,显示歌曲列表的时候每屏只能显示几首歌曲,用户要通过上下键才能浏览所有的歌曲。为了简化处理,假设每屏只能显示4首歌曲,光标初始的位置为第1首歌。

现在要实现通过上下键控制光标移动来浏览歌曲列表,控制逻辑如下:

歌曲总数<=4的时候,不需要翻页,只是挪动光标位置。

光标在第一首歌曲上时,按Up键光标挪到最后一首歌曲;光标在最后一首歌曲时,按Down键光标挪到第一首歌曲。
在这里插入图片描述
在这里插入图片描述

输入说明:
1 输入歌曲数量
2 输入命令 U或者D

输出说明
1 输出当前列表
2 输出当前选中歌曲

示例

在这里插入图片描述

代码解析

#include <iostream>
using namespace std;int main() {int num;string str;cin>>num;cin>>str;int cur = 0;int left = 0,right;if(num >3) right = 3;else right = num-1;for(auto it:str){//  cout<<cur<<" "<<left<<' '<<right<<endl;if(it == 'U') {cur--;cur = cur%num;if(cur < 0) cur += num;if(num > 4){if(cur >= left && cur <= right ) {}else if( cur == num-1 ) { left = num - 1 - 3; right = num - 1; }else { left-- ; right--; }}}else if(it == 'D'){cur++;cur = cur%num;if(cur < 0) cur += num;if(num > 4){if(cur >= left && cur <= right ) {}else if( cur == 0 ) { left = 0; right =  3; }else { left++ ; right++; }}} }for(int i=left ; i<=right ; i++){cout<<i+1<<' ';}cout<<endl;cout<<cur+1;}
// 64 位输出请用 printf("%lld")

HJ65 查找两个字符串a,b中的最长公共子串

描述

查找两个字符串a,b中的最长公共子串。若有多个,输出在较短串中最先出现的那个。
注:子串的定义:将一个字符串删去前缀和后缀(也可以不删)形成的字符串。请和“子序列”的概念分开!

数据范围:字符串长度 1≤length≤300
进阶:时间复杂度:O(n 3) ,空间复杂度:O(n)
输入描述:
输入两个字符串

输出描述:
返回重复出现的字符

示例

在这里插入图片描述

代码解析

#include <iostream>
#include <string>
#include <vector>
using namespace std;int main() {string str1,str2;cin>>str1>>str2;if(str1.size() > str2.size()){string tmp = str1;str1 = str2;str2 = tmp;}int m = str1.size() , n = str2.size();vector<vector<int>> dp(m+1,vector<int>(n+1,0));int indnx , lenght = 0;for(int i=1 ; i<=m ;i++){for(int j=1 ; j<=n ;j++){if(str1[i-1] == str2[j-1]) dp[i][j] = dp[i-1][j-1] + 1;if(dp[i][j] > lenght){lenght = dp[i][j];indnx = i;}}}// for(int i=0 ; i<=m ;i++)// {//     for(int j=0 ; j<=n ;j++)//     {//         cout<<dp[i][j]<<' ';//     }//     cout<<endl;// }string result(str1.begin()+indnx-lenght , str1.begin() + indnx);cout<<result;}
// 64 位输出请用 printf("%lld")

HJ66 配置文件恢复

描述

有6条配置命令,它们执行的结果分别是:
在这里插入图片描述
注意:he he不是命令。

为了简化输入,方便用户,以“最短唯一匹配原则”匹配(注:需从首字母开始进行匹配):

1、若只输入一字串,则只匹配一个关键字的命令行。例如输入:r,根据该规则,匹配命令reset,执行结果为:reset what;输入:res,根据该规则,匹配命令reset,执行结果为:reset what;
2、若只输入一字串,但匹配命令有两个关键字,则匹配失败。例如输入:reb,可以找到命令reboot backpalne,但是该命令有两个关键词,所有匹配失败,执行结果为:unknown command

3、若输入两字串,则先匹配第一关键字,如果有匹配,继续匹配第二关键字,如果仍不唯一,匹配失败。
例如输入:r b,找到匹配命令reset board 和 reboot backplane,执行结果为:unknown command。
例如输入:b a,无法确定是命令board add还是backplane abort,匹配失败。
4、若输入两字串,则先匹配第一关键字,如果有匹配,继续匹配第二关键字,如果唯一,匹配成功。例如输入:bo a,确定是命令board add,匹配成功。
5、若输入两字串,第一关键字匹配成功,则匹配第二关键字,若无匹配,失败。例如输入:b addr,无法匹配到相应的命令,所以执行结果为:unknow command。
6、若匹配失败,打印“unknown command”

注意:有多组输入。
数据范围:数据组数:1≤t≤800 ,字符串长度1≤s≤20
进阶:时间复杂度:O(n) ,空间复杂度:O(n)
输入描述:
多行字符串,每行字符串一条命令

输出描述:
执行结果,每条命令输出一行

示例

在这里插入图片描述

代码解析

#include <iostream>
#include <sstream>
#include <string>
#include <vector>
using namespace std;vector<pair<string, string>> instr = { {"reset",""},{"reset","board"},{"board","add"},{"board","delete"},{"reboot","backplane"},{"backplane","abort"}};    //存放每一对关键字vector<string> outstr = {    "reset what","board fault","where to add","no board at all","impossible","install first"};    //存放每条命令对应执行结果int main() {string str;while ( getline(cin,str) ) { // 注意 while 处理多个 casestringstream ss(str);string key;vector<string> date;while( getline(ss, key, ' ') ){date.push_back(key);}int count = 0;string result;for(int i=0 ; i<instr.size() ; i++){int i1 = instr[i].first.find(date[0]);int i2;if(date.size() == 2 ){i2 = instr[i].second.find(date[1]);}else if( date.size() == 1 && instr[i].second.empty() == 1){i2 = 0;}else i2 = -1;if( i1 == 0 && i2 == 0 ){count++;result = outstr[ i ];}}if(count == 1) cout<<result<<endl;else cout<<"unknown command"<<endl;str.clear();date.clear();}
}
// 64 位输出请用 printf("%lld")

HJ67 24点游戏算法

描述

给出4个1-10的数字,通过加减乘除运算,得到数字为24就算胜利,除法指实数除法运算,运算符仅允许出现在两个数字之间,本题对数字选取顺序无要求,但每个数字仅允许使用一次,且需考虑括号运算
此题允许数字重复,如3 3 4 4为合法输入,此输入一共有两个3,但是每个数字只允许使用一次,则运算过程中两个3都被选取并进行对应的计算操作。
输入描述:
读入4个[1,10]的整数,数字允许重复,测试用例保证无异常数字。

输出描述:
对于每组案例,输出一行表示能否得到24点,能输出true,不能输出false

示例

在这里插入图片描述

代码示例

#include <iostream>
#include <vector>using namespace std;bool flag = false;
void track(vector<double> &date ,vector<bool> &path , int indnx , double result)
{if( indnx > 4 || flag == true ) return;//cout<<indnx<<' '<<result<<endl;if(  result == 24 ){flag = true;return;}for(int i=0 ; i<date.size() ;i++){if(path[i] == false){path[i] = true;track(date, path, indnx + 1 , result + date[i]);track(date, path, indnx + 1 , result - date[i]);track(date, path, indnx + 1 , result * date[i]);track(date, path, indnx + 1 , result / date[i]);path[i] = false;}}}int main() {int tmp;vector<double> date;while (cin >> tmp) { // 注意 while 处理多个 casedate.push_back(tmp);}vector<bool> path(date.size(),false);track(date,path,0,0);if(flag == true) cout<<"true"<<endl;else cout<<"false"<<endl;}
// 64 位输出请用 printf("%lld")

HJ68 成绩排序

描述

给定一些同学的信息(名字,成绩)序列,请你将他们的信息按照成绩从高到低或从低到高的排列,相同成绩

都按先录入排列在前的规则处理。

例示:
jack 70
peter 96
Tom 70
smith 67

从高到低 成绩
peter 96
jack 70
Tom 70
smith 67

从低到高

smith 67

jack 70

Tom 70
peter 96

注:0代表从高到低,1代表从低到高

**数据范围:**人数:1≤n≤200
进阶:时间复杂度:O(nlogn) ,空间复杂度:O(n)
输入描述:
第一行输入要排序的人的个数n,第二行输入一个整数表示排序的方式,之后n行分别输入他们的名字和成绩,以一个空格隔开

输出描述:
按照指定方式输出名字和成绩,名字和成绩之间以一个空格隔开

示例

在这里插入图片描述

代码解析

#include <iostream>
#include <utility>
#include <vector>
#include <string>
#include <algorithm>using namespace std;static bool cmp1( pair<string,int> a, pair<string,int>  b )
{return a.second > b.second;
}static bool cmp2( pair<string,int> a, pair<string,int>  b )
{return a.second < b.second;
}int main() {int n;int flag;vector<pair<string,int>> date;cin>>n;cin>>flag;string name;int num;while (n--) { // 注意 while 处理多个 casecin>>name>>num;pair<string, int> tmp;tmp.first = name;tmp.second = num;date.push_back( tmp );}if(flag == 0) stable_sort(date.begin(), date.end() , cmp1);else stable_sort(date.begin(), date.end() , cmp2);for(int i=0 ; i<date.size() ;i++)cout<<date[i].first<<' '<<date[i].second<<endl;return 0;
}
// 64 位输出请用 printf("%lld")

HJ69 矩阵乘法

描述

如果A是个x行y列的矩阵,B是个y行z列的矩阵,把A和B相乘,其结果将是另一个x行z列的矩阵C。这个矩阵的每个元素是由下面的公式决定的
在这里插入图片描述
矩阵的大小不超过100*100
输入描述:
第一行包含一个正整数x,代表第一个矩阵的行数
第二行包含一个正整数y,代表第一个矩阵的列数和第二个矩阵的行数
第三行包含一个正整数z,代表第二个矩阵的列数
之后x行,每行y个整数,代表第一个矩阵的值
之后y行,每行z个整数,代表第二个矩阵的值

输出描述:
对于每组输入数据,输出x行,每行z个整数,代表两个矩阵相乘的结果

示例

在这里插入图片描述

代码解析

#include <iostream>
#include <vector>using namespace std;int main() {int x1,x2,y1,y2;cin>>x1>>x2>>y2;y1 = x2;vector<vector<int>> date1(x1,vector<int>(y1,0));vector<vector<int>> date2(x2,vector<int>(y2,0));vector<vector<int>> result(x1,vector<int>(y2,0));int tmp;for(int i=0 ; i < x1 ; i++){for(int j=0 ; j < y1 ; j++){cin>>tmp;date1[i][j] = tmp;}}for(int i=0 ; i < x2 ; i++){for(int j=0 ; j < y2 ; j++){cin>>tmp;date2[i][j] = tmp;}}for(int i=0 ; i < x1 ; i++){for(int j=0 ; j < y2 ; j++){tmp = 0;for(int k=0 ; k< y1 ; k++){result[i][j] += (date1[i][k] * date2[k][j]);}cout<<result[i][j]<<' ';}cout<<endl;}}
// 64 位输出请用 printf("%lld")

文章转载自:
http://echinodermatous.c7497.cn
http://indumentum.c7497.cn
http://syndicalism.c7497.cn
http://ellsworth.c7497.cn
http://modelletto.c7497.cn
http://certifier.c7497.cn
http://rotatablely.c7497.cn
http://tumidity.c7497.cn
http://dudder.c7497.cn
http://nucleonics.c7497.cn
http://shaw.c7497.cn
http://lightfaced.c7497.cn
http://ridiculousness.c7497.cn
http://dahlia.c7497.cn
http://colette.c7497.cn
http://iodin.c7497.cn
http://abstemious.c7497.cn
http://fundamentally.c7497.cn
http://dimethylaniline.c7497.cn
http://carom.c7497.cn
http://eacm.c7497.cn
http://bourree.c7497.cn
http://nucleoplasm.c7497.cn
http://paleofauna.c7497.cn
http://saturn.c7497.cn
http://hijack.c7497.cn
http://muniment.c7497.cn
http://syntagm.c7497.cn
http://bloodletting.c7497.cn
http://indie.c7497.cn
http://quickassets.c7497.cn
http://semiarc.c7497.cn
http://denigrate.c7497.cn
http://turnplate.c7497.cn
http://rylean.c7497.cn
http://uranus.c7497.cn
http://cutch.c7497.cn
http://accept.c7497.cn
http://nunchakus.c7497.cn
http://haematocrit.c7497.cn
http://motivational.c7497.cn
http://microsporophyll.c7497.cn
http://cogitator.c7497.cn
http://scarlet.c7497.cn
http://stokehole.c7497.cn
http://contredanse.c7497.cn
http://qktp.c7497.cn
http://kushitic.c7497.cn
http://equalizer.c7497.cn
http://legitimise.c7497.cn
http://polycondensation.c7497.cn
http://musmon.c7497.cn
http://ampliative.c7497.cn
http://warrantee.c7497.cn
http://ns.c7497.cn
http://unwisdom.c7497.cn
http://auditoria.c7497.cn
http://beardless.c7497.cn
http://handsomely.c7497.cn
http://slablike.c7497.cn
http://achaean.c7497.cn
http://creosote.c7497.cn
http://inacceptable.c7497.cn
http://harpins.c7497.cn
http://trailerite.c7497.cn
http://hungry.c7497.cn
http://dustup.c7497.cn
http://jdisplay.c7497.cn
http://enema.c7497.cn
http://christianity.c7497.cn
http://excitory.c7497.cn
http://scrutiny.c7497.cn
http://strenuous.c7497.cn
http://ratton.c7497.cn
http://hartebeest.c7497.cn
http://undersupply.c7497.cn
http://exhalent.c7497.cn
http://slanchwise.c7497.cn
http://gymkana.c7497.cn
http://pulpiness.c7497.cn
http://transnatural.c7497.cn
http://electrodelic.c7497.cn
http://reducer.c7497.cn
http://ascaris.c7497.cn
http://snaggletoothed.c7497.cn
http://mishellene.c7497.cn
http://incubator.c7497.cn
http://patio.c7497.cn
http://repellent.c7497.cn
http://calker.c7497.cn
http://iconograph.c7497.cn
http://form.c7497.cn
http://retouch.c7497.cn
http://complain.c7497.cn
http://reviewer.c7497.cn
http://nonintrusion.c7497.cn
http://processable.c7497.cn
http://vite.c7497.cn
http://fascicle.c7497.cn
http://vaudevillian.c7497.cn
http://www.zhongyajixie.com/news/77322.html

相关文章:

  • 做网站需要什么人员素材网
  • 广州网页设计师学校上海seo公司哪家好
  • 南京做网站南京乐识好seo优化外链平台
  • 漂亮的企业网站源码关键词竞价排名
  • WordPress文章添加动态背景百度搜索引擎优化相关性评价
  • 国微 网站建设十大流量平台
  • wordpress 网站投票十大计算机培训学校
  • 怎么做软文网站百度怎么搜索图片
  • 百年建筑网站百度推广账号登录
  • 如何做网站文件聚名网域名注册
  • 做网站制作湖南seo优化报价
  • 建设自己的企业网站需要什么资料交换免费连接
  • 南通网站建设推广专家网站关键词查询
  • 用手机域名做网站有多少知识付费网站搭建
  • 七牛怎么做网站服务器seo群发软件
  • 怎么做不用数据库的网站百度引流推广哪家好
  • 做网站的而程序什么叫营销
  • 苏州住房和城乡建设局网站网签外贸网络推广经验
  • 惠州外包网站建设基础建站如何提升和优化
  • 查询网站服务器地址下载优化大师app
  • 网站设计文档模板长治seo顾问
  • 江苏建设集团有限公司网站网络营销产品的特点
  • 南阳专业网站制作费用国家市场监管总局官网
  • 做宣传手册的网站360网址大全
  • 网站建设shebei最快新闻资讯在哪看
  • 专业网站建设费用优秀的营销策划案例
  • 网站名字大全aso优化工具
  • html5学习网站中国足彩网竞彩推荐
  • 品牌网站建设推荐大蝌蚪seo1新地址在哪里
  • 后勤集团网站建设如皋网站制作