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

news2025/1/9 2:01:45

编程题得分: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();//0123
		if(n%2){
//			cout<<n<<endl;
//			cout<<s<<endl;
			cout<<0<<endl;
			continue;
		}
		//str to int
		int 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-x
	while(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.coloradmin.cn/o/717444.html

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

相关文章

SAP VC 可配置物料超级BOM简介

`1、可配置物料(Configurable Material)是SAP系统中PP模块一个比较高级的功能。在有些业务中比如:汽车、笔记本、电脑、电梯等产品中,其中组成产品的型号个框架是确认的 ,但是框架内部的BOM是可变的,在客户下销售订单的时候,选取对应的组件 ,让后通过MRP的计算优生产线…

【机器学习】支持向量机(下)

支持向量机&#xff08;下&#xff09; 目录 八、支持向量机的求解实例九、核函数1、核函数的引入2、核函数的示例 十、软间隔1、何为软间隔2、引入软间隔后的目标方程 十一、正则化十二、关于支持向量机的分类十三、数据标准化的影响【机器学习】支持向量机&#xff08;上&…

网络协议与攻击模拟-15-DNS协议

DNS 协议 1、了解域名结构 2、 DNS 查询过程 3、在 Windows server 上部署 DNS 4、分析流量 实施 DNS 欺骗 再分析 一、 DNS 1、概念 ● DNS ( domain name system &#xff09;域名系统&#xff0c;作为将域名的 IP 地址的相互映射关系存放在一个分布式的数据库&#xff0…

【开源项目】智慧仓储~某东数字孪生智慧仓储——开源工程及源码

某东大型仓储工程及源码免费赠送&#xff0c;领先行业智能仓储解决方案&#xff01; 项目介绍 数字孪生技术为仓储管理带来革命性的突破。通过数字孪生的应用&#xff0c;实现智能化的仓储管理&#xff0c;提供准确、高效的仓库操作与分析。 利用数字孪生技术&#xff0c;将数据…

做银行测试,高端大气上档次?

前几天正好去某银行进行测试基础的培训&#xff0c;在和相关负责人聊了些内容后&#xff0c;想了想写一下自己的看法吧。 作为传统行业的银行&#xff0c;可以说对质量的重视程度应该在航天、轨道、军工、机械类似的关键性行业之间&#xff0c;和钱打交道的东西自然 很赚钱不…

AI Chat 设计模式:4. 建造者模式

本文是该系列的第四篇&#xff0c;采用问答式的方式展开&#xff0c;问题由我提出&#xff0c;答案由 Chat AI 作出&#xff0c;灰色背景的文字则主要是我的旁白与思考。 问题列表 Q.1 说说建造者模式A.1Q.2 “将一个复杂对象的构建过程和其表示分离”&#xff0c;这里不是很清…

2023年软考一般什么时候出成绩呢?在线蹬?

软考成绩一般在考试结束后的两个月内公布&#xff0c;而且每次查询时间并不是固定的&#xff0c;比如上半年5月软考考试成绩查询时间一般是7月初&#xff0c;下半年11月初软考成绩查询时间一般就在12月底左右&#xff08;如图所示&#xff09; 过了23年上半年的软考&#xff0c…

电动力学复习提纲

电动力学复习提纲 电动力学核心知识点 电磁场能量密度和能流 场和电荷的能量守恒电磁场的能量密度和能流密度 电偶极矩&#xff0c;磁偶极矩和电四极矩 电极化强度矢量与电偶极矩 磁化强度与磁偶极矩 电势的多级展开 磁矢势的多级展开 非相对论体系的电磁能 静电能 小区…

13万字智慧能源大数据分析平台及能源集团数字化平台建设方案

导读&#xff1a;原文《13万字智慧能源大数据分析平台及能源集团数字化平台建设方案》共335页word&#xff08;获取来源见文尾&#xff09;&#xff0c;本文精选其中精华及架构部分&#xff0c;逻辑清晰、内容完整&#xff0c;为快速形成售前方案提供参考。 目录 智慧能源大数…

干货:在校园里如何创业做外卖平台

干货&#xff1a;在校园里如何创业做外卖平台 外卖能够满足大学生消费者在足不出寝的情况下&#xff0c;方便省时的用餐需求&#xff0c;这也是外卖市场在大学快速发展的主要原因。有关数据显示&#xff0c;40.3%大学生群体月均点外卖次数在5-10次之间&#xff0c;37%40.3%大学…

Mybatis处理复杂查询环境

复杂查询环境 多对一和一对多 多个工作者对应一个协调人 对于工作者(worker)而言&#xff0c;多个工作者关联一个协调人(coordinator)&#xff08;多对一&#xff0c;关联&#xff09; 对于协调人而言&#xff0c;一个协调人有很多工作者&#xff08;一对多&#xff0c;集合&a…

SQL Server表分区

什么是表分区 一般情况下&#xff0c;我们建立数据库表时&#xff0c;表数据都存放在一个文件里。 但是如果是分区表的话&#xff0c;表数据就会按照你指定的规则分放到不同的文件里&#xff0c;把一个大的数据文件拆分为多个小文件&#xff0c;还可以把这些小文件放在不同的…

jvm自带故障处理工具之jmap

jmap是java虚拟机自带的一种内存映像工具。 一般通过jmap可以生成堆的当前使用情况的快照&#xff0c;然后用它来分析或者调优JVM内存使用。 jmap -help jmap -histo:live pid 打印堆的直方图。对于每个Java类&#xff0c;将打印对象数&#xff0c;以字节为单位的内存大小以…

ROS:API操作

目录 一、初始化1.1C版1.2Python版 二、话题与服务相关对象2.1发布对象2.1.1C版2.1.2Python版 2.2订阅对象2.2.1C版2.2.2Python版 2.3服务对象2.3.1C版2.3.2Python版 2.4客户端对象2.4.1C版2.4.2Python版 三、回旋函数3.1C版3.1.1spinOnce()3.1.2spin()3.1.3二者比较 3.2Python…

安装Spark

安装Spark 任务描述 本关任务&#xff1a;完成Spark安装。 相关知识 Apache Spark 是一个新兴的大数据处理通用引擎&#xff0c;提供了分布式的内存抽象。Spark 最大的特点就是快&#xff0c;可比 Hadoop MapReduce 的处理速度快 100 倍。本节将详细说明 Spark 的安装。 下…

C++STL算法之堆算法

堆算法 堆堆算法函数堆算法函数的使用make_heappush_heappop_heapsort_heap 堆 堆就是如图&#xff0c;像这样一种连续的数据&#xff0c;但是注意0的位置不存储数据&#xff0c;目的是为了让编号一置 这里介绍两个概念 大顶堆&#xff1a; 一段内存在二叉数的基础上有序&#…

原生 js (前后端不分离)复选框动态控制表格列的显示隐藏 存储状态

写个div 绑定点击事件 点击设置按钮 让div和复选框显示 <div class"control" οnclick"controlClk()">❁</div> init()// var storeCheckbox window.sessionStorage.getItem(storeCheckbox);function getStore(name) {var storeCheckbox win…

趣谈MySQL 多个%等模糊查询

一、建表并插入数据 1、创建一个people表 DROP TABLE IF EXISTS people; CREATE TABLE people (id int NOT NULL COMMENT 主键,name varchar(45) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NOT NULL COMMENT 姓名,sex tinyint NOT NULL COMMENT 性别,age int NOT N…

怎样优雅地增删查改(一):从0开始搭建Volo.Abp项目

软件系统中数据库或者持久层的基本操作功能可以用Curd描述&#xff0c;Curd即 增加&#xff08;Create&#xff09;、更新&#xff08;Update&#xff09;、读取查询&#xff08;Retrieve&#xff09;和删除&#xff08;Delete&#xff09;&#xff0c; 这4个单词的首字母。 在…

Elasticsearch(2)——映射关系

1 什么是映射 映射&#xff08;mapping&#xff09;就像数据库中的 Schema &#xff0c;描述了文档可能具有的字段或属性、每个字段的 数据类型&#xff0c;比如 Text&#xff0c;Keyword&#xff0c;Integer 或 Date &#xff0c;以及 Lucene 是如何索引和存储这些字 段的。 …