本期题目:IPv4 地址转换成整数
题目
存在一种虚拟 IPv4 地址,由4
小节组成,每节的范围为0~255
,以#
号间隔,
虚拟 IPv4 地址可以转换为一个32
位的整数,例如:
128#0#255#255
,转换为32
位整数的结果为2147549183(0x8000FFFF)
1#0#0#0
,转换为 32 位整数的结果为16777216(0x01000000)
现以字符串形式给出一个虚拟 IPv4 地址,限制第1小节
的范围为1~128
,
即每一节范围分别为(1~128)#(0~255)#(0~255)#(0~255)
,
要求每个 IPv4 地址只能对应到唯一的整数上。
如果是非法 IPv4,返回invalid IP
- 备注:
输入不能确保是合法的 IPv4 地址,
需要对非法 IPv4(空串,含有 IP 地址中不存在的字符,
非合法的#分十进制,十进制整数不在合法区间内)进行识别,返回特定错误
输入
输入一行,虚拟 IPv4 地址格式字符串
输出
输出以上,按照要求输出整型或者特定字符
题解地址
- ⭐️ 华为 OD 机考 Python https://dream.blog.csdn.net/article/details/129088277
- ⭐️ 华为 OD 机考 C++ https://dream.blog.csdn.net/article/details/129232418
- ⭐️ 华为 OD 机考 JS https://dream.blog.csdn.net/article/details/129350750
- ⭐️ 华为 OD 机考 JAVA https://dream.blog.csdn.net/article/details/129759709
- ⭐️ 华为 OD 机考 Golang https://dream.blog.csdn.net/article/details/129341441
- ⭐️ 华为 OD 机考真 C 语言 https://dream.blog.csdn.net/article/details/129411615
华为 OD 机试
刷题技巧
我这里有一个“刷题技巧”,你可以看看,或许可以帮到你:
不要盲目的刷题,凡是讲究策略与技巧,题型是有限的。用自己的方法梳理题型,归纳与总结,就能举一反三、手到擒来。
这个“刷题技巧”,包含了递归、分治、单调栈、并查集、滑动窗口、前缀和、查分、二分查找、 BFS 广搜和 DFS 深搜。
这些题型,都有一些共同点:
递归,都是用一组关键字来实现
BFS 广搜和 DFS 深搜的共同点:
前缀和(前缀法):通过判断值是否相等来判断结果是否为 1。若不相等则返回 1 (否则返回 0)。(也可以通过数组索引的方法)
BFS 广搜的共同点:利用数组索引的方法。