大疆笔试题之不听话的机器人,题目如下
不听话的机器人
时间限制:CC+语言100Ms;其他语言3000s 内存限制:CC+语言6556KB;其他语言589824KB
题目描述:小平时言欢倒腾一些小东西,最近他准备给白己做的小机器人加入一套语音控制的功能,每个指令对应一个动作由于语言转文宇有很多现成的方案,所以小B打算直接复用这些方案,但是语音转成了文字之后,还需要将文字跟具体的动作对应起来。因此小B需要实现一个函数,将语音转换出来的文字,再转换成相应的动作。为了简单实现,小田将语音直接转成了拼音,然后把对应的动作也都起了名字,因此只要预先输入好两者的映射关系,然后输入语音指令就输出相应的动作。然而因为小B的函数有bug,机器人并不想听他的话。
你能帮小B解决这个问题吗?
输入
输入包含多组测试数据,对于每组测试数据第一行输入两个正整数,空格隔开,需要进行映射的命令的数目N和进行调试时发送的语音指令条数M(1<N<1000,1<M<1000)接下来N行,每行输入两个字符串表示语音指令和对应的动作cmd和
action,以空格隔开,每个字符串的长度小于1000,且只有大小写字母。最后M行,每行输入一个字符串表示需要进行调试的语音指令输出 对于每组测试数据: 输出M行,根据调试的语音指令输出对应的动作指令 action
这个题目很简单,整个map就成了,直接上代码
/*
输入:
测试case数
对于每个case:
第一行输入两个正整数N、M,空格隔开,1<N<1000,1<M<1000
1.接下来的N行,每行两个字符串,表示语音指令和对应的动作cmd和 action,
以空格隔开,每个字符串的长度小于1000,且只有大小写字母
2.接下来的M行,每行输入一个字符串表示需要进行调试的语音指令
输出:
对于每组测试数据:
输出M行,根据调试的语音指令输出对应的动作指令 action
*/
#include<iostream>
#include<map>
#include<vector>
#include<string>
#define varName(x) #x
using namespace std;
//检查num是否位于lowbound与upbound之间,超出范围则报错退出
template <typename T>//T为int、float、double等可以直接用"<"、">"比较大小的数字类型
void check_num_range(T num, T lowbound, T upbound) {
if (num < lowbound or num > upbound) {
cout <<