计蒜客 作弊揭发者

鉴于我市拥堵的交通状况,市政交管部门经过听证决定在道路两侧安置自动停车收费系统。当车辆驶入车位,系统会通过配有的摄像头拍摄车辆画面,通过识别车牌上的数字、字母序列识别车牌,通过连接车管所车辆信息数据库确认车辆,进行扣费。

斗智斗勇的好戏一般从此处展开…

一些车主通过在停车时遮挡车牌上的一个或多个数字、字母序列,来阻碍识别系统的识别工作,以此逃避停车费用的缴纳。

车主这简直是用轻轻的一挡搞出来一个世界难题有木有?!管理是一方面,技术解决才是王道啊。

这么难的项目不得不交给计蒜客实验室了。D 神负责识别颜色,E 神负责型号识别,可能的车牌范围就这么一点点的被缩小了。作为实习生的蒜头也是任务艰巨,将已经存在车辆数据库中的可与当前已知信息相匹配的车牌信息筛选出来,这可是整个项目的第一步啊,重要性我就不多说了,加油吧。

输入

输入文件的第一行包含 9 个字符的字符序列代表识别的。

其中可识别的字符已由大写字母和数字显示,“*”表示因为遮挡而未被识别的字符。

输入文件的第二行包含一个整数 n (1 ≤ n ≤ 1000) —— 机动车数据库中的牌照信息的数量。

接下来 n 行,包含相应的牌照信息,每行一个。

牌照信息为长度为 9 的仅包含数字和大写字母的字符串。所有的牌照信息保证各不相同。

输出

输出文件的第一行为一个整数 k (0 ≤ k ≤ n) —— 符合给定要求的牌照数。

接下来的 k 行,输出所有可能的牌照信息。

样例1

输入:

A**1MP19*

4

A001MP199

E885EE098

A111MP199

KT7351TTB

输出:

2

A001MP199

A111MP199

很简单,代码如下:
   
     
  1. #include<iostream>
  2. #include<cstdio>
  3. using namespace std;
  4. char s[1010][11] = {0};
  5. int main () {
  6. scanf("%s", s[0] + 1);
  7. int n, cnt(0);
  8. scanf("%d", &n);
  9. for (int i = 0; i != n; ++i) {
  10. scanf("%s", s[i + 1] + 1);
  11. }
  12. for (int i = 1; i != 10; ++i) {
  13. if (s[0][i] == '*') continue;
  14. for (int j = 0; j != n; ++j) {
  15. if (s[j + 1][0]) continue;
  16. if (s[j + 1][i] != s[0][i]) {
  17. s[j + 1][0] = 1;
  18. ++cnt;
  19. }
  20. }
  21. }
  22. printf("%d\n", n - cnt);
  23. for (int i = 0; i != n; ++i) {
  24. if (s[i + 1][0] == 0) {
  25. printf("%s\n", s[i + 1] + 1);
  26. }
  27. }
  28. return 0;
  29. }





你可能感兴趣的:(计蒜客 作弊揭发者)