华为OD机试2025C卷 - 国际移动用户识别码匹配 (C++ & Python & JAVA & JS & GO)

262 阅读2分钟

国际移动用户识别码(IMSI)匹配

华为OD机考2025年7月11号切换正式机考题库为2025C卷,现在刷2025C卷真题,通过率将大大提高,刷得越多,通过率越高。专栏所有题目提供详细的思路讲解,多语言(C++、JAVA、Python、GO、JavaScript)源码实现,并提供在线OJ系统在线刷题服务。

华为OD机试2025C卷真题题库目录|机考题库 + 算法考点详解

题目描述

小明是核心网工程师,客户交给小明一个任务:给定一个网络配置列表,每个配置是一个字符串,仅有数字和"*"、"?"符号组成。

输入用户的IMSI(国际移动用户识别码),根据以下规则匹配配置列表:

  • "*"匹配0个或连续多个任意字符。
  • "?"匹配下标为奇数的单个字符,比如123?中的"?"可以匹配123456789012345下标为3的字符'4',下标从0开始。

输入描述

输入第一行为网络配置列表,列表中的每个配置是由数字和" * "、" ? "组成的字符串,每个字符串中" * "不会超过一个,"?"若干,网络配置列表长度小于200,每个字符串以英文逗号隔开。

输入第二行为用户的IMSI(国际移动用户识别码),仅有数字组成,长度等于15.

备注

保证输入格式正确,无需考虑格式错误.

输出描述

输出为满足匹配规则的配置字符串列表,列表按字典序升序输出,每个字符以英文逗号隔开。若没有满足条件的配置,则返回字符串"null"

用例1

输入

1234567,1234567*
123456789012345

输出

1234567*

说明

*可以匹配0或多个任意字符,故输出1234567 *

用例2

输入

123?????????345,123????*????345
123456789012345

输出

null

说明

'?'字符只能匹配IMSI中为奇数下标的字符,故都不符合要求,返回null

题解

C++、Java、Python、JavaScript、Go实现源码和详细实现思路解析,点击跳转查看