国际移动用户识别码(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