C++中,有一组字符串const BYTE command[50][10] = { "CLA", //1.查询软件中最小的电流值 "CMA", //2.查询最大输出电流 "CUA", //3.查询软件中最大的电流值 "D", //4.读取EEPROM "E", //5.通讯错误 "F", //6.读取固件分支 "GAA", //7.读取模拟量输入 "H", //8.读取固件类型 "IR", //9.读取设备ID "J", //10.读取已编译固件的部件号码 "MMA", //11.读取当前活动模式 "PD", //12.查询屈光度的值 "PFA", //13.读取信号发生器的频率 "PH", //14.查询所需的位置控制模式 "PLA", //15.查询信号发生器的电流下限 "PO", //16.查询EEPROM的温度值 "PT", //17.查询温度极限值 "PUA", //18.查询信号发生器的电流上限 "Ready", //19.握手协议的返回值 "S", //20.获取状态 "TCA", //21.查询温度 "V", //22.查询固件版本 "X", //23.查询序列号值 "Y", //24.interpoaltion 指令 "Z", //25.读取EEPROM的地址 "A", //26.查询电流值 };快速查找字符串怎么写
时间: 2023-07-02 10:18:17 浏览: 99
可以使用哈希表来快速查找字符串。首先将每个字符串映射到一个唯一的整数,然后将整数作为键存储在哈希表中。这样就能在常数时间内查找字符串了。在C++中,可以使用STL中的unordered_map或者map来实现哈希表。代码示例如下:
```c++
#include <iostream>
#include <unordered_map>
#include <string>
using namespace std;
const int N = 50;
int main()
{
const string command[N] = {"CLA", "CMA", "CUA", "D", "E", "F", "GAA", "H", "IR", "J", "MMA",
"PD", "PFA", "PH", "PLA", "PO", "PT", "PUA", "Ready", "S", "TCA", "V", "X", "Y", "Z", "A"};
unordered_map<string, int> mp;
for (int i = 0; i < N; i++)
mp[command[i]] = i + 1;
string s;
while (cin >> s)
{
if (mp.count(s))
cout << mp[s] << endl;
else
cout << "Not found" << endl;
}
return 0;
}
```
在上面的代码中,我们先将所有字符串存储在一个数组中,然后遍历数组,将每个字符串映射到其对应的整数值(这里的整数值是字符串在数组中的下标加一,因为题目要求从1开始编号)。接下来,我们使用while循环不断输入字符串s,然后在哈希表中查找对应的整数值,如果找到了,就输出整数值,否则输出"Not found"。
阅读全文