您知道如何收到语音邮件,并且此人的联系不好,并且您正在尝试找出如何回叫他们,但是您不确定他们是“ 5”还是“ 8”说过?
这就是挑战。
好消息是,呼叫者两次读出了他们的电话号码,但两个地方都出现了乱码。
您的程序应采用这样的输入:
5551231234 / 5551231234
前十位数是语音邮件中第一次说出电话号码的地方,而第二组是第二次语音电话中说出来的号码。只有...看起来会更像这样:
555?ABC1_36? / 55?522_1?234
- 一个数字后跟一个问号意味着该数字是最好的猜测(例如,“ 5?”表示“可能是5,与重复比较”)。
- 下划线表示一个已知的丢失数字,该数字由于静电而变得模糊不清,根本无法解密。
- 字母就是:字母。将它们视为各自的数字
- ABC-> 2,DEF-> 3,GHI-> 4,JKL-> 5,MNO-> 6,PQRS-> 7,TUV-> 8,WXYZ-> 9
- 所有示例输入均使用大写字母(您可以安全地忽略ToUpper()调用)
- 如果您的语言在小写形式下效果更好,则可以自由使用小写形式输入,并忽略ToLower()调用。只需在您的答案中注明即可。
您还可以假设以下判断调用:
5? / _ -> 5 //5 is the best guess we have, use it
5? / 5? -> 5 //uncertain, but matching
5? / 4? -> ? //conflict
5 / 4 -> ? //conflict
5? / 4 -> 4 //solid information overrides possible value
5 / 4? -> 5 //solid information overrides possible value
_ / _ -> ? //no information available
另外,您可以假定所有输入将包含十位数的电话号码,不包括问号。非十位数的输入(例如1234567 / 1234567
)可以被视为不可解决的(错误的输出)或引发错误。
输入项
0-9A-Z _?/
如上所述,一行字符。
输出量
如果可以将其解析为一个有效的十位数电话号码,请输出该电话号码。否则,输出某种形式的错误指示(例如-1,false或空行)。
与往常一样,最短的胜利。
输入样例:
1234567890 / 1234567890
1234567890? / 1234567890
123456789_ / 1234567890
1234567890? / 123456789_
1234567890 / 1234567890?
1234567890 / 123456789_
123456789_ / 1234567890?
1234567890? / 1234567890?
1234567890? / 1234567891?
123456789_ / 123456789_
555CALLUS1 / 5552255871
404_12?6039 / 4041?1560_9
_GETREVENGE / 16?36?_2838_
1?691460_50 / 16_14609?50
61?08977211 / 612?897725?1
40?0INSTA__ / 8?00_NSTI?LL
3985_534?10 / 39?8?5053_10
7__7294?737 / 7797299?_37
28?897_384?1 / _8?89763861
271168090_ / 27116800?09
6802?148343 / 67?01148343
94_11628?2?6? / 9491162_47?
17?4285_689 / 1__26?52689
6_311?95_38 / 6731194?7?38
380?7DRAGON / 3807378?5?66
4?647_93236 / 5646?6?9__36
365?268898_ / 366267?7?984
GRATEDBATE / IRATEDBATE
5307_079?93 / ____8_____
535_3_0255 / 52?5_3_024?5
55_____088 / 54?2397207?7?
6_48398_95 / _946?398?6_5?
_0_312_3_1 / 81?53123?1?71
____1_____ / 64?255?508?61
8427820607 / 6?424?8?__6?07
50_3707__6 / 52?8375?74?56
615___8255 / 62?526?983?2?1?
__652618__ / 8365261__0
149___933_ / 1_9677?92?31
___7?281562 / 3438?28154?2
5?7?7?___8?3?7?4 / 57_855837_
605_272481 / 605427__81
86?569__731 / 88560?0?7721
1__91654?15 / 17?9?9165715
800NWABODE / 80069ABI?DE
8___9017_0 / 8_2494?12?9_
_024?5?91?470 / 304?17908?7_
42510704_2 / 4_51070492
9338737_89 / 93_873PLUS
327762_401 / 327_MASH01
33093_2058 / 3309_12058
4061_33578 / 40619_3578
559_383197 / 559938_197
94_9746084 / 9459746_84
1_37655238 / 163POLKA_T
_672FRIZZY / 767237499_
8_76318872 / TIP63188_2
51_8404321 / 5178404_21
358_030314 / 358603_314
2597_85802 / 25979_5802
77141_1408 / 7714_91408
330858_457 / 330_586457
4686079_39 / 46_6079239
86457508_6 / 8_45750826
523226626_ / _23BANNANA
_ISSY_ISSY / 44__9548?79?
6?00B_YJILT / 800289KILL?
2?52803___0 / 1526?0390?61?
FI?ND___T?HE / EAS?T?EREGGS?
0_231?95_38 / 0723194?7?38
0?647_39236 / 0646?6?3__36
025?267798_ / 06?6265?9?984
0061_33578 / _0619_3578
我只是确保所有可能的边缘情况都被覆盖了(前11个条目),但除此之外,它几乎是随机的。
更新资料
底部的四个条目添加了前导零(根据Jonathan Allan的建议)。
样本输入的正确输出:
基于乔纳森·艾伦(Jonathan Allan)条目的输出(格式化输出是理想的)。
" / "
,还是可以将它们作为两个标准输入?