2021 RoboCom 世界机器人开发者大赛-高职组(初赛)

编程题得分:100  总分:100

目录

7-1 机器人打招呼 (5分)

输入格式:

输出格式:

输入样例:

输出样例:

7-2 人脸识别 (10分)

输入格式:

输出格式:

输入样例 1:

输出样例 1:

输入样例 2:

输出样例 2:

7-3 月份输出 (10分)

输入格式:

输出格式:

输入样例:

输出样例:

7-4 字母串 (15分)

输入格式:

输出格式:

输入样例:

输出样例:

7-5 增一数 (15分)

输入格式:

输出格式:

输入样例:

输出样例:

7-6 答题卡 (20分)

输入格式:

输出格式:

输入样例:

输出样例:

7-7 救救倒霉鬼 (25分)

输入格式:

输出格式:

输入样例:

输出样例:


7-1 机器人打招呼 (5分)

机器人小白要来 RoboCom 参赛了,在赛场中遇到人要打个招呼。请你帮它设置好打招呼的这句话:“ni ye lai can jia RoboCom a?”。

输入格式:

本题没有输入。

输出格式:

在一行中输出 ni ye lai can jia RoboCom a?

输入样例:

输出样例:

ni ye lai can jia RoboCom a?

编译器

NO_COMPILER

代码

#include<bits/stdc++.h>
using namespace std;int main(){cout<<"ni ye lai can jia RoboCom a?";return 0;
}

编译器输出

 
测试点结果测试点得分耗时内存
0答案正确53.00 ms312 KB

评测结果 答案正确(5 分)

7-2 人脸识别 (10分)

人脸识别是基于人的脸部特征信息进行身份识别的技术,包括人脸图像采集及检测、图像预处理、特征提取以及匹配与识别四大部分。本题请你为机器人警察实现一个非常简单的特征匹配算法,帮助查找罪犯:即给定数据库中存储的某罪犯的双眼间距、鼻梁长度、唇宽,然后与面前这个人的特征数据进行匹配,判断其是否该罪犯。

输入格式:

输入在第一行中给出罪犯的双眼间距 L0​、鼻梁长度 L1​、唇宽 L2​、以及允许的误差范围 T。第二行中给出当前被检测的人的双眼间距 l0​、鼻梁长度 l1​、唇宽 l2​。所有数字均为毫米为单位的长度,是不超过 100 的正整数,同行数字间以空格分隔。

输出格式:

首先在第一行中输出两个人脸特征的误差,格式为:

Diff = D0, D1, D2

其中 D0=L0​−l0​,D1=L1​−l1​,D2=L2​−l2​。如果三项误差的绝对值之和不超过 T,则在第二行输出 Yes,否则输出 No

输入样例 1:

23 60 54 3
23 59 56

输出样例 1:

Diff = 0, 1, -2
Yes

输入样例 2:

23 60 54 3
24 59 56

输出样例 2:

Diff = -1, 1, -2
No

编译器

NO_COMPILER

代码

#include<bits/stdc++.h>
using namespace std;int a1, a2, a3, t, b1, b2, b3;int main(){cin >> a1 >> a2 >> a3 >> t >> b1 >> b2 >> b3;cout<<"Diff = "<<a1-b1<<", "<<a2-b2<<", "<<a3-b3<<endl;if(abs(a1-b1) + abs(a2-b2) + abs(a3-b3) <= t) cout<<"Yes";else cout<<"No";return 0;
}

编译器输出

 
测试点结果测试点得分耗时内存
0答案正确33.00 ms440 KB
1答案正确33.00 ms440 KB
2答案正确13.00 ms456 KB
3答案正确13.00 ms452 KB
4答案正确24.00 ms444 KB

评测结果 答案正确(10 分)

7-3 月份输出 (10分)

本题要求你写一个程序帮助小朋友学习用英语描述月份。已知英文的 12 个月份为:

  • 一月:January

  • 二月:February

  • 三月:March

  • 四月:April

  • 五月:May

  • 六月:June

  • 七月:July

  • 八月:August

  • 九月:September

  • 十月:October

  • 十一月:November

  • 十二月:December

输入格式:

输入包括若干行,每一行里给出一个整数。

输出格式:

对每一行的输入,如果该整数在 1 到 12 之间,则在一行中输出这个数字对应的英文月份单词;否则输出 ? 并结束程序。题目保证程序会结束。

输入样例:

10
5
28
-1

输出样例:

October
May
?

编译器

NO_COMPILER

代码

#include<bits/stdc++.h>
using namespace std;int t;int main(){while(cin>>t){if(t==1) cout<<"January"<<endl;else if(t==2) cout<<"February"<<endl;else if(t==3) cout<<"March"<<endl;else if(t==4) cout<<"April"<<endl;else if(t==5) cout<<"May"<<endl;else if(t==6) cout<<"June"<<endl;else if(t==7) cout<<"July"<<endl;else if(t==8) cout<<"August"<<endl;else if(t==9) cout<<"September"<<endl;else if(t==10) cout<<"October"<<endl;else if(t==11) cout<<"November"<<endl;else if(t==12) cout<<"December"<<endl;else {cout<<"?";break;}}return 0;
}

编译器输出

 
测试点结果测试点得分耗时内存
0答案正确53.00 ms440 KB
1答案正确33.00 ms444 KB
2答案正确13.00 ms440 KB
3答案正确13.00 ms440 KB

评测结果 答案正确(10 分)

7-4 字母串 (15分)

英语老师要求学生按照如下规则写一串字母:

  • 如果写了某个大写字母,下一个就必须写同个字母的小写,或者写字母表中下一个字母的大写;
  • 如果写了某个小写字母,下一个就必须写同个字母的大写,或者写字母表中前一个字母的小写;
  • 当然也可以什么都不写,就结束这个字母串。

例如 aAaABCDdcbBC 就是一个合法的字母串;而 dEFfeFGhI 就是非法的。注意 a 没有前一个字母, Z 也没有下一个字母。

现在面对全班学生交上来的作业,老师请你写个程序自动批改。

输入格式:

输入在第一行给出一个不超过 100 的正整数 N。随后 N 行,每行给出一位学生的作业,即仅由英文字母组成的非空字母串,长度不超过 2×106。

输出格式:

对每位学生的作业,如果正确就在一行中输出 Y,否则输出 N

输入样例:

2
aAaABCDdcbBC
dEFfeFGhI

输出样例:

Y
N

编译器

NO_COMPILER

代码

#include<bits/stdc++.h>
using namespace std;int t;
string s;int main(){cin>>t;while(t--){cin>>s;int n = s.size();int i;for(i = 1; i<n; ++i){if(s[i-1]>='A' && s[i-1]<='Z'){if(s[i] == s[i-1]-'A'+'a' || s[i] == s[i-1]+1) continue;else break;}else if(s[i-1]>='a' && s[i-1]<='z'){if(s[i] == s[i-1]-'a'+'A' || s[i] == s[i-1]-1) continue;else break;}}if(i==n) cout<<"Y"<<endl;else cout<<"N"<<endl;}return 0;
}

编译器输出

 
测试点结果测试点得分耗时内存
0答案正确85.00 ms452 KB
1答案正确24.00 ms452 KB
2答案正确15.00 ms584 KB
3答案正确24.00 ms328 KB
4答案正确246.00 ms4392 KB

评测结果 答案正确(15 分)

7-5 增一数 (15分)

反思:

        这题最坑,4号测试点卡了很久,结果是前导零的坑。输入034,要进行前导零去除处理,变成34,再进行后续的判断。

若一个正整数有 2n 个数位,后 n 位组成的数恰好比前 n 位组成的数大 1,则这个数称为增一数。例如 34、2526、233234 都是增一数。如果这个数还是某个数的平方,则称为平方增一数。你的任务就是判断任一给定正整数是否平方增一数。

输入格式:

输入在第一行中给出一个正整数 N(≤100),随后 N 行,每行给出一个不超过 231 的待判定的正整数。

输出格式:

对每个待判定的正整数,在一行中输出判定结果:如果是平方增一数,则输出 2;如果只是普通增一数,则输出 1;如果不是增一数,则输出 0。

输入样例:

3
528529
2324
5678

输出样例:

2
1
0

编译器

NO_COMPILER

代码

#include<bits/stdc++.h>
#define int long long
using namespace std;int t;
int ss;signed main(){cin>>t;while(t--){
//		cin>>s;
//		int n = s.size();string s;cin>>ss;int n = 0;while(ss){n++;s.push_back('0' + ss%10);ss /= 10;}for(int i = 0; i<s.size()/2; ++i){swap(s[i], s[s.size()-1-i]);}
//		cout<<n<<endl;
//		cout<<s<<endl;
//		int n = s.size();//0123if(n%2){
//			cout<<n<<endl;
//			cout<<s<<endl;cout<<0<<endl;continue;}//str to intint a = 0, b = 0, i;for(i = 0; i<n/2; ++i){a *= 10;a += s[i]-'0';}for(i; i<n; ++i){b *= 10;b += s[i]-'0';}
//		cout<<a<<" "<<b<<endl;int c = a;for(int i = 1; i<=n/2; ++i) c *= 10;c += b;//		cout<<a<<" "<<b<<" "<<c<<endl;int ans = 0;if(a+1 == b && ((int)sqrt(c))*((int)sqrt(c)) == c) ans = 2;else if(a+1 == b) ans = 1;else ans = 0;		cout<<ans<<endl;		}return 0;
}/*
卡了半天 */

编译器输出

a.cpp: In function ‘int main()’:
a.cpp:21:19: warning: comparison between signed and unsigned integer expressions [-Wsign-compare]for(int i = 0; i<s.size()/2; ++i){~^~~~~~~~~~~
a.cpp:39:8: warning: statement has no effect [-Wunused-value]for(i; i<n; ++i){^
测试点结果测试点得分耗时内存
0答案正确84.00 ms452 KB
1答案正确15.00 ms440 KB
2答案正确14.00 ms456 KB
3答案正确16.00 ms436 KB
4答案正确13.00 ms452 KB
5答案正确13.00 ms312 KB
6答案正确24.00 ms604 KB

评测结果 答案正确(15 分)

7-6 答题卡 (20分)

新浪微博上有网友发文称:“朋友买了本玻尔X海森堡的物理大佬同人本,送了300道高数题。更绝的是,要做完题目按照答案涂答题卡,涂出一个二维码,扫描二维码才能看到特典,做错了就看不到了……”那张传说中的答题卡如下图所示:若答案为 4 位整数(位数不足时在前面补足 0),则前两位为横坐标,后两位为纵坐标。若一题有两小问,则第一问答案为横坐标,第二问答案为纵坐标。若答案为分数,则分子为横坐标,分母为纵坐标。

本题就请你根据答案帮助读者填写答题卡。

输入格式:

输入首先在第一行给出两个正整数:2<n≤90 为二维码的规模,即二维码是由 n×n 个小方块组成的大方块,左下角的小方块对应坐标 (1, 1),右上角的小方块对应坐标 (n, n);另一个 m(<n2)是答案的个数。最后 m 行,每行按以下格式之一给出一题的答案:或者是一个不超过 4 位的整数;或者是两小问的答案 答案1;答案2;或者是一个分数 分子/分母。这里保证每个答案都可以解析为一个二维码中的方块位置(即不存在超出二维码范围的坐标)。

输出格式:

输出 n 行,每行 n 个字符,空格用 . 表示,涂了答案的黑格用 # 表示。

输入样例:

5 7
205
3;2
4/5
101
3;3
4/3
5;1

输出样例:

.#.#.
.....
..##.
..#..
#...#

编译器

NO_COMPILER

代码

#include<bits/stdc++.h>
//#define int long long 
using namespace std;int n, m, len;
char g[100][100];
string s;signed main(){cin>>n>>m;for(int i = 1; i<=n; ++i){for(int j = 1; j<=n; ++j){g[i][j] = '.';}}//y, n-xwhile(m--){cin>>s;len = s.size();int i;for(i = 0; i<len; ++i){if(s[i] == ';') break;if(s[i] == '/') break;}int a = 0, b = 0;if(i==len){int num = 0;for(int j = 0; j<len; ++j){num *= 10;num += s[j]-'0';}
//			cout<<num;a = num / 100;b = num % 100;}else{for(int j = 0; j<i; ++j){a *= 10;a += s[j]-'0';}for(int j = i+1; j<len; ++j){b *= 10;b += s[j]-'0';}}g[n-b+1][a] = '#';}for(int i = 1; i<=n; ++i){for(int j = 1; j<=n; ++j){cout<<g[i][j];}cout<<"\n";}return 0;
}

编译器输出

 
测试点结果测试点得分耗时内存
0答案正确124.00 ms564 KB
1答案正确24.00 ms576 KB
2答案正确64.00 ms564 KB

评测结果 答案正确(20 分)

7-7 救救倒霉鬼 (25分)

倒霉鬼抗着一大箱银行票据去邮寄,却不慎掉进了西湖…… 他奋力游上岸并且顺便抢救了一些票据。但还是有一些票据落到了西湖底必须补做…… 于是请你写程序帮帮倒霉鬼,给他列出来需要重新补做的票据有哪些?

输入格式:

输入首先给出全部一箱票据的信息:在第一行给出不超过 105 的正整数 N,随后 N 行,每行给出一张票据的编号。题目保证编号不重复。

随后是抢救回来的票据的信息,首先是一个小于 N 的非负整数 M,随后 M 行,每行给出一份抢救回来的票据的编号。题目保证编号存在。

编号为长度不超过 12 的、由英文字母和数字组成的字符串。

输出格式:

按字典序递减输出丢失的票据的编号,每个编号占一行。

输入样例:

5
A20190289
B20018372
A19873001
T27346900
B00247834
3
T27346900
A19873001
B20018372

输出样例:

B00247834
A20190289

编译器

NO_COMPILER

代码

#include<bits/stdc++.h>
//#define int long long 
using namespace std;int n, m;
string s;
set<string> se;int cnt;
string ans[100005];signed main(){cin>>n;for(int i = 1; i<=n; ++i){cin>>s;se.insert(s);}cin>>m;for(int i = 1; i<=m; ++i){cin>>s;se.erase(s);}auto t = se.begin();for(t; t!=se.end(); t++){ans[++cnt] = *t;}for(int i = cnt; i>=1; --i) cout<<ans[i]<<endl;	return 0;
}

编译器输出

a.cpp: In function ‘int main()’:
a.cpp:24:7: warning: statement has no effect [-Wunused-value]for(t; t!=se.end(); t++){^
测试点结果测试点得分耗时内存
0答案正确156.00 ms3524 KB
1答案正确16.00 ms3520 KB
2答案正确16.00 ms3512 KB
3答案正确497.00 ms11312 KB
4答案正确4186.00 ms11832 KB

评测结果 答案正确(25 分)

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

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

相关文章

开始编写Python程序之Python小工具:word转pdf、压缩文件、解压文件、jpg转png

1、下载Python编译器 PyCharm官网下载地址对于个人编程&#xff0c;下载免费版的Community即可 2、创建一个Python项目 Python的最佳实现是为每个项目创建virtualenv。为此&#xff0c;请展开Project Interpreter&#xff1a;New Virtualenv Environment节点&#xff0c;然后…

AI视觉赢未来|深眸科技出席元宇宙装备展,“智与质”实现双重升级

6月29日&#xff0c;2023昆山元宇宙国际装备展在昆山国际会展中心圆满落幕&#xff0c;此次展会不仅为我们呈现最先进的元宇宙装备、最前沿的元宇宙技术、最潮流的元宇宙应用&#xff0c;还为工业元宇宙的发展蓄势赋能。 浙江深眸科技有限公司&#xff08;以下简称深眸科技&am…

MATLAB基础篇(下)

本文为MATLAB基础篇&#xff08;上&#xff09;的后续。 二、 MATLAB基本语法 7、基本绘图方法 Ⅰ、 MATLAB绘图的一般步骤 对数轴进行采样对采样点计算相应的函数值, 得到平面(或空间)上的点的数据运用绘图命令将数据进行图形化显示 x-1:0.01:1; %对数轴进行采样ysin(1./x);…

MySQL数据库架构

MySql数据库架构 网络连接层&#xff1a;提供与mysql服务器建立连接的支持&#xff0c;负责连接管理、授权认证、安全等。 核心服务层&#xff1a;主要包含系统管理和控制工具、连接池、SQL接口、解析器、查询优化器和查询缓存六个部分。 存储引擎层&#xff1a;负责Mysql中数据…

React V6实现类似与vue的eventBus

功能背景 想要实现类似于vue的eventBus的功能&#xff0c;由一个组件通知其他一个或多个组件。应用场景&#xff1a;比如一个可视化大屏的界面&#xff0c;当筛选条件变化的时候&#xff0c;要同时通知到大屏中所有图表一起变化。&#xff08;当然使用store也是可以的&#xff…

【NX】NX二次开发设置对象高亮和颜色模板实现

在NX二次开发当中&#xff0c;我们经常需要高亮一个或者多个对象&#xff0c;或者设置对象的颜色方便实现&#xff0c;直接调用函数稍微显得麻烦&#xff0c;尤其是当我们需要处理的对象是容器的时候&#xff0c;于是我写了几个简单的模板实现&#xff0c;方便调试。 //author&…

docker 教程笔记,win11

1、如何执行container 当git clone一个带Dockerfile的项目时&#xff0c;先打开终端&#xff0c;跳转到该项目文件夹。 使用如下命令构建镜像image docker build -t project_name . 注&#xff1a; project_name为该项目名&#xff0c;后面必须要有空格和点。 执行完毕后&#…

mutate使用(日志过滤)

1.前言 mutate 过滤器是Logstash中的一个常用过滤器&#xff0c;用于对事件中的字段进行修改、重命名、删除和添加操作。它提供了多种操作选项&#xff0c;如替换字段值、添加新字段、删除字段、重命名字段等。mutate 过滤器可以在事件流水线的任何阶段使用&#xff0c;且不需…

vue 移动端开发vw适配方案rem适配方案 + vant框架 + unocss|tailwindcss

写在前面的话&#xff1a;看了这篇文章&#xff0c;有些东西名词啥的不懂的&#xff0c;或者有疑问的推荐百度&#xff0c;因为写的太多真的显得很啰嗦&#xff01; 1.移动端开发适配 目前移动端适配&#xff0c;在市面上主流适配方案无非就两种&#xff0c;rem方案和vw方案。…

宏晶微 音频处理芯片 MS7124

MS7124是一款高性能24bit数字立体声音频DAC&#xff0c;该DAC采用Sigma-Delta结构&#xff0c;支持标准的I2S数字信号输入&#xff0c;输出支持立体声和单声道。

蓝桥杯专题-试题版-【九宫重排】【格子刷油漆】【回文数字】【国王的烦恼】

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例点击跳转>软考全系列点击跳转>蓝桥系列 &#x1f449;关于作者 专注于Android/Unity和各种游…

【多种优化算法比较】混沌引力搜索算法(CGSA)(Matlab代码实现)

&#x1f4a5;&#x1f4a5;&#x1f49e;&#x1f49e;欢迎来到本博客❤️❤️&#x1f4a5;&#x1f4a5; &#x1f3c6;博主优势&#xff1a;&#x1f31e;&#x1f31e;&#x1f31e;博客内容尽量做到思维缜密&#xff0c;逻辑清晰&#xff0c;为了方便读者。 ⛳️座右铭&a…