当前位置:   article > 正文

2021 RoboCom 世界机器人开发者大赛-高职组(初赛)_7-7 救救倒霉鬼

7-7 救救倒霉鬼

废话

哎,摸鱼摸久了,上周啥都没写,现在还是打算摸鱼,于是花2小时写了最简单的高职组的初赛

实话说,这没什么难的题目

那我就不写注释啥的了,直接上代码吧QAQ(反正也没人看,代码又简单,应该不会有人连这么短的代码都看不懂吧)

博客园那里也就不发了,博客园那我写的都好冷清,顶多自己复习瞅瞅QAQ

写这篇博客也就是相当于打卡了

题解

7-1 机器人打招呼

题目:

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

输入格式:

本题没有输入。

输出格式:

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

输入样例:

输出样例:

ni ye lai can jia RoboCom a?

代码:

  1. #include<iostream>
  2. using namespace std;
  3. int main()
  4. {
  5. cout<<"ni ye lai can jia RoboCom a?";
  6. return 0;
  7. }

7-2 人脸识别

题目:

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

输入格式:

输入在第一行中给出罪犯的双眼间距 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:

  1. 23 60 54 3
  2. 23 59 56

输出样例 1:

  1. Diff = 0, 1, -2
  2. Yes

输入样例 2:

  1. 23 60 54 3
  2. 24 59 56

输出样例 2:

  1. Diff = -1, 1, -2
  2. No

代码:

  1. #include<iostream>
  2. #include<cmath>
  3. using namespace std;
  4. int main()
  5. {
  6. int a,b,c,d;
  7. cin>>a>>b>>c>>d;
  8. int a1,b1,c1;
  9. cin>>a1>>b1>>c1;
  10. cout<<"Diff = "<<a-a1<<", "<<b-b1<<", "<<c-c1<<endl;
  11. if(abs(a1-a)+abs(b1-b)+abs(c1-c)>d)
  12. cout<<"No";
  13. else
  14. cout<<"Yes";
  15. return 0;
  16. }

 7-3 月份输出

题目:

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

  • 一月:January

  • 二月:February

  • 三月:March

  • 四月:April

  • 五月:May

  • 六月:June

  • 七月:July

  • 八月:August

  • 九月:September

  • 十月:October

  • 十一月:November

  • 十二月:December

输入格式:

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

输出格式:

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

输入样例:

  1. 10
  2. 5
  3. 28
  4. -1

输出样例:

  1. October
  2. May
  3. ?

代码:

  1. #include<iostream>
  2. using namespace std;
  3. int main()
  4. {
  5. string str[20]={"January",
  6. "February",
  7. "March",
  8. "April",
  9. "May",
  10. "June",
  11. "July",
  12. "August",
  13. "September",
  14. "October",
  15. "November",
  16. "December",
  17. };
  18. int n;
  19. while(cin>>n)
  20. {
  21. if(n<=12&&n>0)
  22. cout<<str[n-1]<<endl;
  23. else
  24. {
  25. cout<<"?"<<endl;
  26. break;
  27. }
  28. }
  29. return 0;
  30. }

7-4 字母串

题目:

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

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

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

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

输入格式:

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

输出格式:

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

输入样例:

  1. 2
  2. aAaABCDdcbBC
  3. dEFfeFGhI

输出样例:

  1. Y
  2. N

代码:

  1. #include<iostream>
  2. using namespace std;
  3. int main()
  4. {
  5. int n;
  6. cin>>n;
  7. for(int i=0;i<n;i++)
  8. {
  9. string str;
  10. cin>>str;
  11. bool flag=0;
  12. int len=str.length();
  13. for(int i=0;i<len-1;i++)
  14. {
  15. if(str[i]<='z'&&str[i]>='a')
  16. {
  17. if(str[i+1]!=(str[i]+'A'-'a')&&str[i+1]!=(str[i]-1))
  18. {
  19. flag=1;
  20. break;
  21. }
  22. }
  23. else if(str[i]<='Z'&&str[i]>='A')
  24. {
  25. if(str[i+1]!=(str[i]-'A'+'a')&&str[i+1]!=(str[i]+1))
  26. {
  27. flag=1;
  28. break;
  29. }
  30. }
  31. }
  32. if(flag)
  33. cout<<"N"<<endl;
  34. else
  35. cout<<"Y"<<endl;
  36. }
  37. return 0;
  38. }

7-5 增一数

题目:

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

输入格式:

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

输出格式:

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

输入样例:

  1. 3
  2. 528529
  3. 2324
  4. 5678

输出样例:

  1. 2
  2. 1
  3. 0

代码:

  1. #include<iostream>
  2. #include<cmath>
  3. using namespace std;
  4. int main()
  5. {
  6. int n;
  7. cin>>n;
  8. for(int i=0;i<n;i++)
  9. {
  10. long long a,b;
  11. cin>>a;
  12. int len=0;
  13. b=a;
  14. while(b)
  15. {
  16. len++;
  17. b/=10;
  18. }
  19. len/=2;
  20. if(a%((long long)pow(10,len))-1!=a/(long long)pow(10,len))
  21. cout<<0<<endl;
  22. else
  23. {
  24. if((long long)sqrt(a)*(long long)sqrt(a)==a)
  25. cout<<2<<endl;
  26. else
  27. cout<<1<<endl;
  28. }
  29. }
  30. return 0;
  31. }

7-6 答题卡

题目:

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

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

输入格式:

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

输出格式:

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

输入样例:

  1. 5 7
  2. 205
  3. 3;2
  4. 4/5
  5. 101
  6. 3;3
  7. 4/3
  8. 5;1

输出样例:

  1. .#.#.
  2. .....
  3. ..##.
  4. ..#..
  5. #...#

代码:

  1. #include<iostream>
  2. #include<cstring>
  3. #include<sstream>
  4. #include<string>
  5. using namespace std;
  6. char mg[100][100];
  7. int main()
  8. {
  9. int n,m;
  10. cin>>n>>m;
  11. for(int i=0;i<m;i++)
  12. {
  13. string str;
  14. cin>>str;
  15. stringstream ss;
  16. ss<<str;
  17. int a,b;
  18. char c;
  19. ss>>a;
  20. if(ss.rdbuf()->in_avail()==0)
  21. {
  22. mg[a/100][a%100]='#';
  23. continue;
  24. }
  25. ss>>c>>b;
  26. mg[a][b]='#';
  27. }
  28. for(int i=n;i>=1;i--)
  29. {
  30. for(int j=1;j<=n;j++)
  31. if(mg[j][i]!='#')
  32. cout<<'.';
  33. else
  34. cout<<'#';
  35. cout<<endl;
  36. }
  37. return 0;
  38. }

7-7 救救倒霉鬼

题目:

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

输入格式:

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

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

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

输出格式:

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

输入样例:

  1. 5
  2. A20190289
  3. B20018372
  4. A19873001
  5. T27346900
  6. B00247834
  7. 3
  8. T27346900
  9. A19873001
  10. B20018372

输出样例:

  1. B00247834
  2. A20190289

代码:

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<map>
  4. using namespace std;
  5. string str[100010];
  6. map<string,int,greater<string> >ma;
  7. int main()
  8. {
  9. int n;
  10. scanf("%d",&n);
  11. for(int i=0;i<n;i++)
  12. {
  13. cin>>str[i];
  14. ma[str[i]]++;
  15. }
  16. scanf("%d",&n);
  17. for(int i=0;i<n;i++)
  18. {
  19. cin>>str[i];
  20. ma[str[i]]--;
  21. }
  22. for(auto i:ma)
  23. {
  24. if(i.second==1)
  25. cout<<i.first<<endl;
  26. }
  27. return 0;
  28. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/weixin_40725706/article/detail/639107
推荐阅读
相关标签
  

闽ICP备14008679号