项目需求:
字符串数组中保存着5次字符识别同一编号的结果,判断超过3次识别出相同的字符串,即为识别成功。
所以需要判断5个字符串中是否有大于等于3个相同的?(等同于统计数组中各元素出现的次数)
1、使用QMap来实现
QStringList m_sOCRcharList ; //存5次识别出的结果进行判断
m_sOCRcharList << "B025292A03"<< "B025292A03"<< "440H523420"<< "B025292A03"<< "B025292A03";
QMap<QString, int> m_qmap; //统计字符数组中各个元素出现的个数
if (5 == m_sOCRcharList.size())
{
for (int i = 0; i < m_sOCRcharList.size(); i++)
{
int num;
num = m_qmap[m_sOCRcharList.at(i)];
m_qmap.insert(m_sOCRcharList.at(i), num == 0 ? 1 : num + 1);
}
QMap<QString, int>::iterator it; //遍历map
for (it = m_qmap.begin(); it != m_qmap.end(); ++it)
{
if (it.value() >= 3) //识别出3张相同,即认为识别成功
{
qDebug() << "成功识别出的字符串:" << it.key();
}
qDebug() << it.key() << "个数:" <<it.value();
}
/* m_qmap.clear();
m_sOCRcharList.clear();*/
}