项目需求:
字符串数组中保存着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();*/ }